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PRIORITY INFORMATION 

This application claims benefit of priority to the following provisional 
applications, each of which is hereby incorporated by reference in its entirety: 

Serial No. 60/202,975 filed May 9, 2000 titled Distributed Computing 
Environment; 

Serial No. 60/208,011 filed May 26, 2000 titled Distributed Computing 
Environment; 

Serial No. 60/209,430 filed June 2, 2000 titled Distributed Computing 
Environment; 

Serial No. 60/209,140 filed June 2, 2000 titled Distributed Computing 
Environment; and 

Serial No. 60/209,525 filed June 5, 2000 titled Distributed Computing 
Environment. 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

This invention relates to distributed computing environments including Web- 
centric and Internet-centric distributed computing environments, and more particularly to 
a method for receiving results data in a heterogeneous distributed computing environment 
based upon a message passing model for connecting network clients and services. 

2. Description of the Related Art 
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Intelligent devices are becoming increasingly common. Such devices range from 
smart appliances, personal digital assistants (PDAs), cell phones, lap top computers, 
desktop computers, workstations, mainframes; even, super computers. Networks are also 
becoming an increasingly common way to interconnect intelligent devices so that they 
may communicate with one another. However, there may be large differences in the 
computing power and storage capabilities of various intelligent devices. Devices with 
more limited capabilities may be referred to as small footprint devices or "thin" devices. 
Thin devices may not be able to participate in networks interconnecting more capable 
devices. However, it may still be desirable to interconnect a wide variety of different 
types of intelligent devices. 

The desire to improve networking capabilities is ever increasing. Business 
networks are expanding to include direct interaction with suppliers and customers. 
Cellular phones, personal digital assistants and Internet-enabled computers are 
commonplace in both business and the home. Home networks are available for 
interconnecting audio/visual equipment such as televisions and stereo equipment to home 
computers, and other devices to control intelligent systems such as security systems and 
temperature control thermostats. High bandwidth mediums such as cable and ASDL 
enable improved services such as Internet access video on demand, e-commerce, etc. 
Network systems are becoming pervasive. Even without a formal network, it is still 
desirable for intelligent devices to be able to communicate with each other and share 
resources. 

Currently, traditional networks are complex to set up, expand and manage. For 
example, adding hardware or software to a network often requires a network 
administrator to load drivers and configure systems. Making small changes to a network 
configuration may require that the entire network be brought down for a period of time. 
Also, certain intelligent devices may not support the necessary interfaces to communicate 
on a given network. 
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What is needed is a simple way to connect various types of intelligent devices to 
allow for communication and sharing of resources while avoiding the interoperability and 
complex configuration problems existing in conventional networks. Various 
technologies exist for improving the addition of devices to a network. For example, 
many modem I/O buses, such as the Universal Serial Bus, 1394 and PCI, support plug 
and play or dynamic discovery protocols to simplify the addition of a new device on the 
bus. However, these solutions are limited to specific peripheral buses and are not suitable 
for general networks. 

A more recent technology, Jini from Sun Microsystems, Inc., seeks to simplify the 
connection and sharing of devices such as printers and disk drives on a network. A 
device that incorporates Jini may announce itself to the network, may provide some 
details about its capabilities, and may immediately become accessible to other devices on 
the network. Jini allows for distributed computing where the capabilities of the various 
devices are shared on a network. The Jini technology seeks to enable users to share 
services and resources over a network. Another goal of the Jini technology is to provide 
users with easy access to resources anywhere on the network while allowing the network 
location of the user to change. Jini also seeks to simplify the task of building, 
maintaining and altering a network of devices, software and users. 

Jini requires that each Jini enabled device has a certain amount of memory and 
processing power. Typically, a Jini enabled device is equipped with a Java Virtual 
Machine (JVM). Thus, Jini systems are Java technology centered. Java is a high level 
object oriented programming language developed by Sun Microsystems, Inc. Java source 
code may be compiled into a format called bytecode, which may then be executed by a 
Java Virtual Machine. 

Bytecode is computer source code that is processed by a virtual machine, rather 
than the "real" computer machine, the hardware processor. The virtual machine converts 
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generalized machine instruction (the bytecode) into specific machine instructions 
(instructions that the computer's processor will understand). Using a language that comes 
with a virtual machine for each platform, the source language statements may be 
compiled only once and may then run on any platform that supports the virtual machine. 
5 The Java progranmiing language is an example of such a language, and the Java Virtual 
Machine (JVM) is an example of a virtual machine platform that supports programs 
written in the Java progranmiing language. 
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Since Java Virtual Machines may be provided for most computing platforms, Java 
10 and thus Jini provide for a certain amount of platform independence. The Jini 
architecture leverages off the assumption that the Java programming language is the 
implementation language for the components of the Jini system. The ability to 
dynamically download and run Java code is central to many features of the Jini 
architecture. 



The purpose of the Jini architecture is to federate groups of devices and software 
components into a single dynamic distributed system. A key concept within the Jini 
architecture is that of a service. A service is an entity that can be used by a person, a 
program, or another service. Two examples of services are printing a document and 

20 translating from one word processor format to another. Jini allows the members of a Jini 
system to share access to services. Services in a Jini system communicate with each other 
by using a service protocol, which is a set of interfaces written in the Java programming 
language. Services are found and resolved in a Jini system by a look-up service. A look- 
up service maps interfaces indicating the functionality provided by a service to sets of 

25 objects that implement the service. 



Descriptive entries may also be associated with a service. Devices and 
applications use a process known as discovery to register with the Jini network. Once 
registered, the device or application places itself in the look-up service. The look-up 
30 service may store not only pointers to these services on the network, but also may store 
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the code for accessing these services. For example, when a printer registers with the 
look-up service, it loads its printer driver and/or an interface to the driver into the look-up 
service. When a client wants to use the printer, the driver and driver interface get 
downloaded from the look-up service to the client. This code mobility means that clients 
can take advantage of services from the network without pre-installing or loading drivers 
or other software. 

Communication between services in a Jini system is accomplished using the Java 
Remote Method Invocation (RMI). RMI is a Java programming language enabled 
extension to traditional remote procedure call mechanisms. RMI allows not only data to 
be passed from object to object around the Jini network, but full objects including code as 
well. Jini systems depend upon this ability to move code around the network in a form 
that is encapsulated as a Java object. 

Access to services in a Jini system is lease based. A lease is a grant of guaranteed 
access over a time. Each lease is negotiated between the user of the service and the 
provider of the service as part of the service protocol. A service may be requested for 
some period and access may be granted for some period presumably considering the 
request period. Leases must be renewed for a service to remain part of the Jini system. 

Figure 1 illustrates the basic Jini technology stack. The Jini technology defines a 
distributed programming model 12 (supported by JavaSpaces, leases, and object 
templates). Object communication in Jini is based on an RMI layer 14 over a TCP/IP 
capable networking layer 16. 

Jini is a promising technology for simplifying distributed computing. However, 
for certain types of devices, Jini may not be appropriate. The computing landscape is 
moving toward a distributed. Web-centric service and content model where the 
composition of client services and content changes rapidly. The client of the future may 
be a companion type device that users take with them wherever they go. Such a device 
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may be a combination of a cell phone and a PDA for example. It would be desirable for 
such devices to be able to communicate and share resources with more powerful devices 
as well as thinner or less powerful devices. 

Also, with the advent of the Internet and resulting explosion of devices connected 
to the net, a distributed programming model designed to leverage this phenomenon is 
needed. An enabling technology is needed that facilitates clients connecting to services in 
a reliable and secure fashion. Various clients from thick to thin and services need to be 
connected over the Internet, corporate Internets, or even within single computers. It is 
desirable to abstract the distance, latency and implementation from both clients and 
services. 

The key challenge for distributed computing technology is to be scalable from 
powerful thick clients down to very thin clients such as embedded mobile devices. 
Current distributed computing technologies, such as Jini, may not be scalable enough for 
the needs of all types of clients. Some devices, such as small footprint devices or 
embedded devices, may lack sufficient memory resources and/or lack sufficient 
networking bandwidth to participate satisfactorily in current distributed computing 
technologies. The low end of the client spectrum, including embedded mobile devices, 
often have limited or fixed code execution environments. These devices also may have 
minimal or no persistent storage capabilities. Most small, embedded mobile devices do 
not support a Java Virtual Machine. Most code-capable small clients run native code 
only. Also, most small devices have little more than flash memory or battery backed 
RAM as their sole persistent storage media. The size of the storage is often very small 
and sometimes read-only in nature. Furthermore, the access time of this type of storage 
media is often an order of magnitude greater than hard disk access time in more powerful 
clients. 

Existing connection technologies, such as Jini, may not be as scalable as desired 
because they are too big. For example, Jini requires that all participants support Java; 
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however, many small clients may not have the resources for a Java Virtual Machine. 
Furthermore, due to its use of RMI, Jini requires that clients be able to download code 
and content. Jini may augment the existing client platform by downloading new classes, 
which may pose security and size concerns for small devices such as embedded devices. 
Jini works by clients and resources conrmiunicating by passing code and data. When a 
client activates a Jini service, the service may return its results to the client, which may 
include a large amount of code or content. In Jini, a client may call a method and a large 
object may be returned, and thus downloaded. The client may not have the resource to 
accept the returned object. Also, RMI and Java itself require a lot of memory. Many 
small foot print devices may not have the resources to participate effectively or at all in 
current distributed computing technologies. 

Another concern with existing distributed computing technologies is that they 
often require certain levels of connection capabiHty and protocols. For example, Jini 
assumes the existence of a network of reasonable speed for connecting computers and 
devices. Jini also requires devices to support TCP/IP network transport protocol. 
However, many smaller devices may have limited connection capabilities. Small devices 
may have high latency or low speed network connections and may not support TCP/IP. 

As mentioned above, Jini requires devices to support Java and thus include a Java 
Virtual Machine, which requires a certain amount of processing and storage capabilities 
that might not be present for many small devices. This also restricts the flexibility of Jini 
in that non-Java devices may not directly participate in a Jini system. Since Jini requires 
Java, it may be deemed a homogenous environment. However, it is desirable to have a 
distributed computing facility for heterogeneous distributed computing that scales from 
extremely small embedded devices through PDA's and cell phones to laptops and beyond 
even to the most powerful computers. 

Other heterogeneous solutions exist, such as the Common Object Request Broker 
Architecture (CORBA). CORBA is an architecture that enables program objects to 
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communicate with one another regardless of the programming language they were written 
in or what operating system they're running on. However, CORBA does not address all 
of the connection issues that are addressed by Jini. Also, CORBA suffers from similar 
scalability problems as Jini. 

Technology such as Jini and CORBA use a code-centric programming model to 
define the interface between remote components. A code-centric programming model 
defines programmatic interfaces or API's for communication between remote clients or 
components. The API's may be defined in a particular programming language. The 
API's must be agreed to by all software components to ensure proper interoperability. 
Since all access to components is through the use of these standards API's, the code that 
implements these API's must be present in the client platform. The code may be 
statically linked into the platform or dynamically downloaded when needed. Many 
embedded or mobile devices simply cannot accept code dynamically from a network due 
to the quality control issues involved as well as the reliance on a single language and 
program execution environment. Data-centric models, such as networking protocols, may 
avoid the dependence on moving code; however, such protocols are not rich enough to 
easily provide for distributed computing and they also lack the ease of programming with 
code and other programming features, such as type safety. 

Conventional distributed computing systems rely on the ability of a program 
executing on a first device to be able to remotely call a program on a second device and 
have the results retumed to the first device. The Remote Procedure Call (RPC) is a basic 
mechanism for remotely calling a program or procedure. CORBA and Jini are both based 
on the ability to remotely invoke program methods. However, communicating by passing 
code or objects, such as in Jini or CORBA, may be somewhat complex. For example, as 
mentioned above, Jini uses the Java Remote Method Invocation (RMI) to communicate 
between services. In order for a client to move Java objects to and from remote locations, 
some means of serialization/deserialization is needed. Such current facilities in the Java 
Development Kit (JDK) rely upon the reflection API to determine the content of a Java 
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object, and ultimately that code must consult the Virtual Machine. This code is quite 
large and inefficient. 

The fundamental problems with the current method for doing 
serialization/deserialization include its size, speed, and object traversal model. Code 
outside the JVM does not know the structure or graph of a Java object and thus must 
traverse the object graph, pulling it apart, and ultimately must call upon the JVM. 
Traditional serialization and reflection mechanisms for storing and moving Java objects 
are just not practical for all types of devices, especially thinner devices. Some of the 
difficulties with Java reflection and serialization are that an object's graph (an object's 
transitive closure) reflection is difficult to do outside the JVM. Serialization is too large, 
requiring a large amount of code. Also, serialization is a Java specific object interchange 
format and thus may not be used with non-Java devices. 

The Jini distributed computing model requires the movement of Java objects 
between Java devices. Thus, the serialization mechanism itself is not platform 
independent since it may not be used by non-Java platforms to send and receive objects. 
Serialization is a homogenous object format - it only works on Java platforms. 
Serialization uses the reflection API and may be limited by security concerns, which often 
must be addressed using native JVM dependent methods. The reflection API may 
provide a graph of objects, but is inefficient due to the number of calls between the JVM 
and the code calling the reflection methods. 

The use of Java reflection to serialize an object requires an application to ping 
pong in and out of the JVM to pick apart an object one field at a time as the transitive 
closure of the object is dynamically analyzed. Deserializing an object using Java 
deserialization requires the application to work closely with the JVM to reconstitute the 
object one field at a time as the transitive closure of the object is dynamically analyzed. 
Thus, Java serialization/deserialization is slow and cumbersome while also requiring 
large amounts of application and JVM code as well as persistent storage space. 
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Even for thin clients that do support Java, the Jini RMI may not be practical for 
thin clients with minimal memory footprints and minimal bandwidth. The serialization 
associated with the Jini RMI is slow, big, requires the JVM reflection API, and is a Java 

5 specific object representation. Java deserialization is also slow, big and requires a 
serialized-object parser. Even Java based thin clients may not be able to accept huge Java 
objects (along with needed classes) being returned (necessarily) across the network to the 
client as required in Jini. A more scalable distributed computing mechanism is needed. 
It may be desirable for a more scalable distributed computing mechanism to address 

10 security concerns and be expandable to allow for the passing of objects, such as Java 
objects, and even to allow for process migration from one network mode to another. 

D 

Object based distributed computing systems need persistent storage. However, as 
discussed above, attempts at object storage are often language and operating system 
specific. In addition, these object storage systems are too complicated to be used with 
many small, embedded systems. For example, the Jini technology uses JavaSpaces as 
persistent object containers. However, a JavaSpace can only store Java objects and 
cannot be implemented in small devices. Each object in a JavaSpace is serialized and 
pays the above-described penalties associated with Java serialization. It may be desirable 
to have a heterogeneous object repository for distributed computing that may scale from 
small to large devices. 

It is desirable in object oriented distributed systems to be able to locate object 
repositories and find particular objects within those repositories. As mentioned above, 
25 the Jini look-up server may not be practical for small devices with small memory 
footprints. A more efficient mechanism for locating object stores may be desirable. 

Distributed object access also desires a fair and efficient sharing mechanism. As 
described above Jini currently uses a leasing mechanism to share objects. However, Jini 
30 leases are time based which may result in a number of problems. For example, the 
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current object holder might have no idea how long to lease an object and may hold it too 
long. Also, the use of time-based leases may require that time be synchronized between 
multiple machines. Moreover time based leasing may require operating system support. 
Also, Jini leases are established and released via RMI. Thus, the Jini leasing mechanism 
5 suffers from the above-noted problems with using RMI. Other leasing mechanisms may 
be desirable. 



D 



Generally speaking, it is desirable for small memory foot print mobile client 
devices to be able to run a variety of services, both legacy and new, in a distributed 
10 environment. The types of small clients may include cell phones and PDA's with a 
variety of different networking interfaces, typically low bandwidth. Often these devices 
have very small displays with limited graphics, but they could include laptops and 
notebook computers, which may have a larger display and more sophisticated graphics 
capabilities. The services may be a wide range of applications as well as control 
15 programs for devices such as printers. It is desirable for a mobile client to be able to use 



p these services wherever they may be. 



A mobile client will often be at a temporary dynamic network address, so 
networking messages it sends cannot be routed beyond that networking interface 

20 (otherwise there may be collisions when two different clients on different networks have 
the same dynamic address). Mobile clients often do not have the capability for a full 
function browser or other sophisticated software. The displays may limit the client from 
running certain applications. Traditional application models are based on predetermined 
user interface or data characteristics. Any change to the application requires 

25 recompilation of the application. 

It may be desirable for such clients to have a mechanism for finding and invoking 
distributed applications or services. The client may need to be able to run even large 
legacy applications which could not possibly fit in the client's memory footprint. As 
30 discussed above, current technology, such as Jini, may not be practical for small footprint 
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devices. The pervasiveness of mobile thin clients may also raise additional needs. For 
example, it may be desirable to locate services based on the physical location of the user 
and his mobile client. For example, information about the services in a local vicinity may 
be very helpful, such as local restaurants, weather, traffic maps and movie info. 

Similarly, information about computing resources, such as printers in a particular 
location, may be helpful. Current technologies do not provide an automatic mechanism 
for locating services based on physical location of the client. Another need raised by thin 
mobile clients is that of addressing the human factor. Thin mobile clients typically do not 
contain ergonomic keyboards and monitors. The provision of such human factor services 
and/or the ability to locate such services in a distributed computing environment may be 
desirable. 
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SUMMARY OF THE INVENTION 



Embodiments of a mechanism for providing results gates in a distributed 
computing environment are described. Results gates may be provided to clients in the 
distributed computing environment and used by the clients to access results generated by 
services on behalf of the clients. A client may generate a request message for a service. 
The request message may include information requesting the service to perform a 
function on behalf of the client. In one embodiment, the request message may be 
generated by a client method gate, and may include a data representation language (e.g. 
XML) representation of the method call. 

The client may send the message to the service. In one embodiment, the message 
may be sent by a client message gate. In another embodiment, the message may be sent 
by a client method gate. In yet another embodiment, the message may be generated by a 
client method gate, passed to a client message gate, and sent to the service by the client 
message gate. The service may receive the message and generate results in response to 
the message. In one embodiment, the message includes a data representation language 
representation of a computer programming language method call. In this embodiment, a 
service method gate may receive the message and regenerate the method call from the 
representation of the method call. A computer programming language method (e.g. Java 
method) may then be invoked using the method call. The invoked method may generate 
the results. The service may store the generated results. The service may then send an 
address (e.g. URI) of the results to the client. Alternatively, the service may return the 
results directly to the client in one or more messages. In one embodiment, the results may 
be comprised in a data representation language document. In another embodiment, the 
results may be comprised in a data representation language representation of a computer 
prograrrmiing language object (e.g. Java object). 

A results gate may be generated for accessing the results. In one embodiment, the 
results gate may be generated by the service and sent to the client. In another 
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embodiment, the service may send an address of the results to the client, and the client 
may generate the results gate from information (e.g. an advertisement for the results) 
located through the address. In yet another embodiment, the service may send the results 
to the client, and the client may generate a results gate for the results. In one 

5 embodiment, a message schema may be provided in used in generating the results gate. 
The message schema may include information describing one or more data representation 
language messages for accessing the results. In one embodiment, a gate on the client may 
generate the results gate. In one embodiment, the gate may provide information to a gate 
factory, and the gate factory may generate the results gate. In one embodiment, the gate 

10 may be a method gate, and the results may have been generated in response to a computer 
programming language method performed by the service. In one embodiment, the results 
gate may share authentication information with the generating gate. For example, the 
gate may attach an authentication credential of the client to outgoing messages. The gate 
may provide the same authentication credential to the results gate for use in outgoing 



J 15 messages. 

m 

2 The results may be accessed through the results gate. In one embodiment, the 

i K 

Pi results are an object (e.g. Java object), and the results gate is an object proxy for the 

^ results object. In this embodiment, a client process (e.g. Java program) accessing the 

O 20 results object through the results gate may not be able to distinguish the results gate 

O 

object proxy from the real results object. In this embodiment, the results gate may be 
returned to the process as results of the method call made by the process. In one 
embodiment, the results gate is a method gate and provides a method interface to the 
results. In this embodiment, the results gate supports a set of method calls for accessing 
25 the results. When receiving a method call from a client process, the results gate may 
convert the method call into a data representation language representation of the method 
call and send the representation in a message to the results location (e.g. space service) 
where the method call may be regenerated and the method invoked with the method call. 
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In one embodiment, a results gate may generate another results gate. For 
example, the results gate may generate a message to access the results, and may receive a 
response to the message. The results gate may then generate a second results gate 
subsequent to receiving the response. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



Figure 1 is an illustration of a conventional distributed computing technology 

stack; 

Figure 2 is an illustration of a distributed computing environment programming 
model according to one embodiment; 

Figure 3 is an illustration of messaging and networking layers for a distributed 
computing environment according to one embodiment; 

Figure 4 is an illustration of a discovery service for finding spaces advertising 
objects or services in a distributed computing environment according to one embodiment; 

Figure 5 illustrates client profiles supporting static and formatted messages for a 
distributed computing environment according to one embodiment; 

Figure 6 is an illustration of a distributed computing model employing XML 
messaging according to one embodiment; 

Figure 7 illustrates a platform independent distributing computing environment 
according to one embodiment; 

Figure 8 is an illustration of a distributed computing model in which services are 
advertised in spaces according to one embodiment; 

Figure 9 is an illustration of a distributed computing model in which results are 
stored in spaces according to one embodiment; 
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Figure 10 is an illustration of client and service gates as messaging endpoints in a 
distributed computing model according to one embodiment; 

Figure 10b is an illustration a message endpoint generation according to a schema 
for accessing a service according to one embodiment. 

Figure 11a illustrates gate creation in a distributed computing environment 
according to one embodiment; 

Figure lib illustrates gate creation and gate pairs in a distributed computing 
environment according to one embodiment; 

Figure 12 is an illustration of possible gate components in a distributed computing 
environment according to one embodiment; 

Figure 13 is an illustration of proxy client for a conventional browser to 
participate in the distributed computing environment according to one embodiment; 

Figure 14 illustrates the use of a method gate to provide a remote method 
invocation interface to a service in a distributed computing environment according to one 
embodiment; 

Figure 15 is an illustration of the use of a space in a distributed computing 
environment according to one embodiment; 

Figure 16 illustrates advertisement structure according to one embodiment; 

Figure 17 illustrates one example of advertisement state transitions that an 
advertisement may undergo during its lifetime according to one embodiment; 
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Figure 18 is an illustration various space location mechanisms in a distributed 
computing environment according to one embodiment; 

Figure 19 is an illustration of space federations in a distributed computing 
environment according to one embodiment; 

Figure 20 is a flow diagram illustrating client formation of a session with a space 
service in a distributed computing environment according to one embodiment; 

Figure 21 is an illustration of a space event type hierarchy for one embodiment; 

Figure 22 is a flow diagram illustrating service instantiation in a distributed 
computing environment according to one embodiment; 

Figure 23 is an illustration of a default space in a distributed computing 
environment according to one embodiment; 

Figure 24 illustrates an example of a device bridging proximity-based devices 
onto another transport mechanism to allow the services provided by the proximity-based 
devices to be accessed by devices outside the proximity range of the devices, according to 
one embodiment; 

Figure 25 is an illustration of the use of lease renewal messages in a distributed 
computing environment according to one embodiment; 

Figure 26a is a flow diagram illustrating an authentication service providing an 
authentication credential to a client according to one embodiment; 
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Figure 26b is a flow diagram expanding on step 1002 of Figure 26a and 
illustrating an authentication service generating an authentication credential according to 
one embodiment; 

Figure 27 illustrates one embodiment of a bridging mechanism; 

Figure 28 illustrates an example of a space discovery protocol mapped to an 
external discovery service according to one embodiment; 

Figure 29 illustrates bridging a client external to the distributed computing 
environment to a space in the distributed computing environment according to one 
embodiment; 

Figure 30 is an illustration of a proxy mechanism according to one embodiment; 

Figure 31 illustrates one embodiment of a client with an associated display and 
display service according to one embodiment; 

Figures 32A and 32B illustrate examples of using schemas of dynamic display 
objects according to one embodiment; 

Figure 33A illustrates a typical string representation in the C programming 
language; 

Figure 33B illustrates an example of a conventional string function; 

Figure 33C illustrates an efficient method for representing and managing strings 
in general, and in small footprint systems such as embedded systems in particular 
according to one embodiment; 
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Figure 34 illustrates a process of moving objects between a client and a service 
according to one embodiment; 

Figures 35a and 35b are data flow diagrams illustrating embodiments where a 
virtual machine (e.g. JVM) includes extensions for compiling objects (e.g. Java Objects) 
into XML representations of the objects, and for decompiling XML representations of 
(Java) objects into (Java) objects; 

Figure 36 illustrates a client and a service accessing store mechanisms in the 
distributed computing environment, according to one embodiment; 

Figure 37 illustrates process migration using an XML representation of the state 
of a process, according to one embodiment; 

Figure 38 illustrates a mobile client device accessing spaces in a local distributed 
computing network, according to one embodiment; 

Figure 39a illustrates a user of a mobile device discovering the location of 
docking stations, according to one embodiment; 

Figure 39b illustrates a mobile client device connecting to a docking station, 
according to one embodiment; 

Figure 40a illustrates an embodiment of embedded devices controlled by a control 
system and accessible within the distributed computing environment, according to one 
embodiment; 

Figure 40b illustrates a device control system connected via a network (e.g. the 
Internet) to embedded devices accessible within the distributed computing environment, 
according to one embodiment; 
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Figure 41 is a flow diagram illustrating creating a gate according to one 
embodiment; 

Figure 42a is a flow diagram illustrating a client sending a message to a service 
according to one embodiment; 

Figure 42b is a flow diagram illustrating a service receiving a message from a 
client and using an authentication service to authenticate the message according to one 
embodiment; 

Figure 42c is a flow diagram illustrating the general process of a client and service 
exchanging messages with embedded authentication credential according to one 
embodiment; 

Figure 43 is a flow diagram illustrating a mechanism for checking the integrity of 
messages according to one embodiment; 

Figure 44 is a flow diagram illustrating a mechanism for leasing resources 
according to one embodiment; 

Figures 45a-45e are flow diagrams illustrating various embodiments of a 
mechanism for communicating between clients and services using method gates; 

Figure 46 is a flow diagram illustrating a mechanism for sending objects from 
services to clients using XML representations of the objects; 

Figure 47 is a flow diagram illustrating a mechanism for secure object 
decompilation on a client device; 
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Figure 48 is a flow diagram illustrating a mechanism for migrating processes 
using data representation language representations of the processes in a distributed 
computing environment; and 

Figure 49 is a flow diagram illustrating a mechanism for providing results gates 
according to one embodiment. 



While the invention is susceptible to various modifications and alternative forms, 
specific embodiments thereof are shown by way of example in the drawings and will 
herein be described in detail. It should be understood, however, that the drawings and 
detailed description thereto are not intended to limit the invention to the particular form 
disclosed, but on the contrary, the intention is to cover all modifications, equivalents and 
alternatives falling within the spirit and scope of the present invention. 
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DETAILED DESCRIPTION OF EMBODIMENTS OF THE INVENTION 



Overview of Embodiments for Distributed Computing 

Turning now to Figure 2, a distributed computing environment programming 
model is illustrated. The model includes API layer 102 for facilitating distributed 
computing. The API layer 102 provides an interface that facilitates clients connecting to 
services. The API layer 102 is concerned with the discovery of and the connecting of 
clients and services. The API layer 102 provides send message and receive message 
capabilities. This messaging API may provide an interface for simple messages in a 
representation data or meta-data format, such as in the extensible Mark-up Language 
(XML). Note that while embodiments are described herein employing XML, other meta- 
data type languages or formats may be used in alternate embodiments. In some 
embodiments, the API layer may also provide an interface for messages to communicate 
between objects or pass objects, such as Java objects. API's may be provided to discover 
an object repository or "space", find a particular object, claim and release an object, and 
write or take an object to or from the object repository. Objects accessible through API 
layer 102 may be represented by a representation data format, such as XML. Thus, an 
XML representation of an object may be manipulated, as opposed to the object itself. 

API layer 102 sits on top of a messaging layer 104. The messaging layer 104 is 
based on a representation data format, such as XML. In one embodiment, XML messages 
are generated by messaging layer 104 according to calls to the API layer 102. The 
messaging layer 104 may provide defined static messages that may be sent between 
clients and services. Messaging layer 104 may also provide for dynamically generated 
messages. In one embodiment, an object, such as a Java object, may be dynamically 
converted into an XML representation. The messaging layer 104 may then send the XML 
object representation as a message. Conversely, the messaging layer 104 may receive an 
XML representation of an object. The object may then be reconstituted from that 
message. 
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In one embodiment, messages sent by messaging layer 104 may include several 
basic elements, such as an address, authentication credentials, security tokens, and a 
message body. The message system transmission and receive mechanisms may be 
completely stateless. Any notion of state may be embedded in the message stream 
between sender and receiver. Thus, message transmission may be done asynchronously. 
In a preferred embodiment, no connection model is imposed. Thus, transports such as 
TCP are not required. Also, error conditions may be limited to non-delivery or security 
exceptions. 

Messaging layer 104 sits on top of a message capable networking layer 106. In a 
preferred embodiment, messaging layer 104 does not require that a particular networking 
protocol be used. TCP/IP and UDP/IP are examples of message capable protocols that 
may be used for message capable networking layer 106. However, other more specialized 
protocols such as the Wireless Application Protocol (WAP) may also be used. Other 
possible message protocols are IrDA and Bluetooth network drivers beneath the transport 
layer. Networking layer 106 is not limited to a single reliable connection protocol, such 
as TCP/IP. Therefore, connection to a larger variety of devices is possible. 

In one embodiment, message capable network layer 106 may be implemented 
from the networking classes provided by the Java2 Micro Edition (J2ME) platform. The 
Java2 Micro Edition platform may be suitable for smaller footprint devices that do not 
have the resources for a full Java platform or in which it would not be efficient to run a 
full Java platform. Since J2ME already provides a message capable family of networking 
protocols (to support sockets), it follows that for the small footprint cost of adding 
messaging layer 104, distributing computing facilities may be provided for small devices 
that already include J2ME. 

Message capable networking layer 106 may also be provided by the Java 
Development Kit's (JDK) java.net networking classes. Alternatively, any message 
capable networking facilities may be used for message capable networking layer 106. In 
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a preferred embodiment, a reliable transport is not required, thus embedded devices 
supporting an unreliable data gram transport such as UDP/IP may still support the 
messaging layer. 

Thus, thin clients may participate in a distributed computing environment by 
simply adding a thin messaging layer 104 above a basic networking protocol stack. As 
shown in Figure 3, a basic system includes messaging layer 104 on top of a networking 
layer 106. The networking layer may provide for reliable messages, e.g. TCP, or 
unreliable messages, e.g. UDP. The Internet Protocol (IP) is shown in Figure 3 as an 
example of protocol that may be used in networking layer 106. However, the distributed 
computing environment does not require IP. Other protocols may be used in the 
distributed computing environment besides IP. A network driver such as for Ethernet, 
Token Ring, Bluetooth, etc. may also be part of the networking layer. Many small clients 
already provide a network driver and transport protocol such as UDP/IP. Thus, with the 
addition of the thin XML based messaging layer, the device may participate in the 
distributed computing environment. 

Thus, the foundation for the distributed computing environment is a simple 
message passing layer implemented on top of reliable connection and/or unreliable data 
grams. The messaging technology is very different from communications technologies 
employed in other distribution computing systems, such as Jini which employs the Java 
remote method invocation (RMI). The message passing layer 104 supports an 
asynchronous, stateless style of distributed progranmiing, instead of the synchronous, 
state-full style predicated by RMI. Moreover, message passing layer 104 is based on a 
data representation language such as XML and thus copies data, but not code, from 
source to destination, unlike RMI. By using a representation data language, such as 
XML, messaging layer 104 may interoperate with non-Java and non-Jini platforms in a 
seamless fashion because Java code is not assumed on the sending or receiving end of a 
message. Moreover, unlike RMI, messaging layer 104 does not require a reliable 
transport mechanism such as TCP/IP. 
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The message passing layer may provide simple sendQ and receiveQ methods to 
send a message specified as an array or string of bytes, for example. The send() method 
may return immediately, performing the data transfer asynchronously. For flow control 
5 purposes a callback method may be supplied which is invoked in the event that the sendQ 
method throws an exception indicating it cannot handle the sendQ request. The receive() 
method may be synchronous and may return the next available message. 



The message passing layer may also provide methods for storing XML 
10 representations of objects, services and content in "spaces". A space is named and 
accessed on the network using an URI (Uniform Resource Identifier). The URI may be a 
URL (Uniform Resource Locator) or a simpler version of a URL. In some embodiments, 
the URL class may be too large. For such embodiments a simpler resource locator may 
be used that specifies the protocol for moving the messages between client and server, 
15 protocol dependent host ED, protocol dependent port ID, and a space name. 

An XML representation of an object may be added to a space using a write() 
method provided by the messaging layer. In one embodiment, the object and the 
client-specified name may be supplied as parameters. In one embodiment, the write 

20 method may translate the object into its XML representation. A take() method may be 
provided to return the object and remove it from the space. A find() method may be 
provided to return a specified object from its XML representation in a space. The find() 
method may also be used to return an array of matching objects in a space given a class. 
Each of these space methods is implemented using the message-passing layer. A lease 

25 mechanism may also be provided, as described in more detail below. 



A discovery service may be provided for clients as a general search facility that 
may be used by a client to locate a particular space. Rather than attempt to define a 
complicated search protocol which may not be feasible for a thin client to implement, the 
30 discovery service may offload the actual search to XML-based search facilities, leaving 
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the discovery service simply to provide interface functionality to the client. The approach 
is illustrated in Figure 4. In one embodiment, the discovery service receives a string 
specifying something to locate, and it sends an XML message to a known discovery 
front-end (perhaps found in a default space), which then parses the string and makes a 
corresponding XML query to a search facility (which may be an internet search facility). 
The discovery front-end may parse what it obtains from the search facility and repackage 
it as an array of strings (each string may be a URI for each found space) which it may 
send in an XML message to the client. It should be noted that the discovery service does 
not require that the messaging be atop a connection-oriented transport. Thus, even very 
thin clients that do not have TCP could use such a discovery service. The discovery 
front-end makes it possible for the client to discover spaces without a browser or search 
facility on the client. The client only needs a simple facility that sends a string that 
specifies keywords to the front-end, which interfaces with a search facility. 

A client may be any platform that can send a message using at least a subset of the 
API and messaging layers. In one embodiment the API layer may provide for both static 
(or raw) and formatted (or cooked) messages. A server may be any platform capable of 
receiving and fulfilling message requests. An explicit raw message send may be provided 
that moves a series of bytes from a client to a server or to another client. The message 
type may be specified as reliable (e.g. TCP) or unreliable (e.g. UDP). The smallest of 
devices may use raw unreliable message passing as their sole means of participation in 
the distributed computing environment. The device may use these messages to announce 
its presence and its status. Such small devices may also receive raw messages to 
implement certain functions, such as turning a feature on or off. 

Message-based services such as spaces may send and receive reliable formatted 
messages. A space message may be formatted with a well-defined header and with XML. 
In one embodiment, a formatted message send may occur when a client uses a space 
method to claim, write, or take objects from a space. The message contents may be 
dynamically formatted in XML and contain well-defined headers. Figure 5 illustrates 
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client profiles supporting formatted and static messages. By using static messages, small 
devices may use a smaller profile of code to participate in the distributed computing 
environment. For example, a small device could just send basic pre-defined messages. 
Depending on the client, the static pre-defined messages may consume a small amount of 
memory (e.g. <200 bytes). Static messages may also be an option even for larger devices. 
On the other hand, the dynamic XML messages may be useful when object values are not 
known at compile time. 

Turning now to Figure 6, a distributed computing model is illustrated that 
combines a messaging system with XML messages and XML object representation. The 
platform independence of XML may be leveraged so that the system may provide for a 
heterogeneous distributed computing environment. Thus, client 110 may be implemented 
on almost any platform instead of a particular platform like Java. The messaging system 
may be implemented on any network capable messaging layer, such as Internet protocols 
(e.g. TCP/IP or UDP/IP). Thus, the computing environment may be distributed over the 
Internet. In one embodiment, the messaging system may also use shared memory as a 
quick interprocess message passing mechanism when the client and/or space server 
and/or service are on the same computer system. The distributed computing model of 
Figure 6 may also be very scalable because almost any size client can be configured to 
send and/or receive XML messages. 

As shown in Figure 6, two kinds of software programs may run in the distributed 
computing model: services 112 and clients 110. Services 112 may advertise their 
capabilities to clients wishing to use the service. The services 112 may advertise their 
capabilities in spaces 114. As illustrated in Figure 7, clients 110 and services 112 may or 
may not reside within the same network device. For example, devices 120 and 124 each 
support one client, whereas service 112a and client 110b are implemented in the same 
device 122. Also, as illustrated in Figure 7, no particular platform is required for the 
devices to support the clients and services. For example, device 120 is Java based, 
whereas device 124 provides a native code runtime environment. 
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A device may be a networking transport addressable unit. Example devices 
include, but by no means are limited to: PDAs, cellular/mobile phones, notebook 
computers, laptops, desktop computers, more powerful computer systems, even 
5 supercomputers. Both clients and services may be URI-addressable instances of software 
(or firmware) that run on devices. Using the distributed computing environment 
architecture, a client may run a service. A space is a service that manages a repository of 
XML documents. Even though it is redundant, the term, space service, may be used 
herein for readability. A software component may be both a client and service at different 
10 times. For example, when a service uses a space (e.g. to advertise itself), that service is a 
client of the space. 

Figure 8 illustrates the basic model of the distributed computing environment in 
one embodiment. The distributed computing environment may connect clients 110 to 
services 112 throughout a network. The network may be a wide area network such as the 
Internet, The network may also be a combination of networks such as a local area 
network (LAN) connected to a wireless network over the Internet. As shown in Figure 8, 
a service 112 publishes an advertisement 132 for itself (represented in XML) in a space 
114. The advertisement 132 specifies the service's XML schema and URI address. Then, 
a client 110 may look up the advertisement 132. The cHent 110 may use the 
advertisement 132 to instantiate a gate 130. The gate 130 allows the client 110 to run the 
service 1 12, by sending (and receiving) XML messages to (and from) the service 112. 



y 

Us 
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20 



Some results of running a service may be returned to the client in an XML 
25 message. However, since other results may be too large for a small client to receive and 
consume at once, a service 112 may put those results or an XML representation of the 
results 134 in a space 114, as shown in Figure 9, and return them by reference (in an 
XML message) to the client 1 10, rather than by value. Examples of methods of returning 
a reference to results include, but are not limited to: returning in the message a URI 
30 referencing the results in a space, and: returning in the message an XML document 
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including the URI of the results. Later, the client 1 10 may access the results, or pass them 
by reference to another service. The space in which results may be stored may be 
different from the space in which the service is advertised. 

In one embodiment, the distributed computing environment uses XML for content 
definition, advertisement and description. New content for the distributed computing 
environment (messages and advertisements for example) are defined in XML. Existing 
content types (e.g. developed for other environments) may also be described using XML 
as a level of indirection (meta-data). XML provides a powerful means of representing 
data throughout a distributed system because, similar to the way that Java provides 
universal code, XML provides universal data. XML is language agnostic and is 
self-describing. The XML content may be strongly typed and validated using schemas. 
Using a provided XML schema, the system may ensure that only valid XML content is 
passed in a message. XML content may also be translated, into other content types such 
as HTML and WML. Thus, clients that do not understand XML may still use the 
distributed computing environment services. 

In one embodiment, the distributed computing environment messages may define 
the protocol used to connect clients with services, and to address content in spaces and 
stores. The use of messages to define a protocol allows many different kinds of devices 
to participate in the protocol. Each device may be free to implement the protocol in a 
manner best suited to its abilities and role. For example, not all devices are capable of 
supporting a Java runtime environment. The distributed computing environment protocol 
definition does not require nor imply the use of Java on a device. Nor does it preclude it. 

A service's capabilities may be expressed in terms of the messages the service 
accepts. A service's message set may be defined using an XML schema. An XML 
message schema defines each message format using XML typed tags. The tag usage rules 
may also be defined in the schema. The message schema may be a component of an 
XML advertisement along with the service's message endpoint used to receive messages. 
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The distributed computing environment may allow clients to use all or some subset of a 
service's capabilities. Security policies may be employed to enforce the set of capabilities 
given to a client. For example, once a set of capabilities has been given to a client, the 
client may not change that set without proper authorization. This model of capability 
definition allows for services levels that range from a base set of capabilities to an 
extended set. Extensions may be added to services by adding to the number of 
recognized messages. 

In one embodiment, all operations in the distributed computing environment are 
embodied as XML messages sent between clients and services. Storage (both transient 
and persistent) providers are examples of services that enable clients and services to store, 
advertise, and address content. Clients and services may find each other and broker 
content using a transient storage space. Services may place a content or service 
advertisement in a space. The advertisement may describe the content type or the 
capabilities of the service. Clients may subsequently browse spaces looking for 
advertisements that match a desired set of capabilities. When a client finds a matching 
advertisement, a communication channel may be established which may enable bi- 
directional message passing to the service backing the advertisement. In one 
embodiment, the communication channel is authenticated. Results (which are just 
another content type) from service operations may be returned directly to the client in a 
response message, advertised and stored in a space, or advertised in a space, but stored 
persistently. Stored results may be addressed using a URI (e.g. returned in the response 
message) and may have an associated authentication credential. 

Message Gates 

As discussed above, the distributed computing environment leverages off the use 
of a data description language, such as XML. XML may be used to describe a target 
entity (e.g. document, service, or client) to an extent such that code may be generated to 
access that entity. The generated code for accessing the target entity may be referred to as 
a message gate. Thus, in one embodiment, the distributed computing environment differs 
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from other distributed computing environments in that instead of passing the necessary 
code between objects necessary to access the other object, the environment provides 
access to XML descriptions of an object or target so that code may be generated based on 
the XML description to access the target. The distributed computing environment may 
use an XML schema to ensure type safety as well as a programming model (e.g. 
supported messages) without having to agree upon language specific APIs, just XML 
schemas. 

Code generated from an XML schema may also incorporate the language, 
security, type safety, and execution environment characteristics of the local platform. The 
local platform may thus have control over the generated code to ensure that it is bug-free 
and produces only valid data according to the schema. The generated code may conform 
to the client's code execution environment (e.g. Java, C++, Smalltalk), as well as its 
management and security framework (Web-server and/or operating system). 

Note that the distributed computing environment does not require that code 
generated from an XML schema be generated "on the fly" at runtime. Instead, some or 
all of the code may be pre-generated for categories (or classes) of services, and then 
linked-in during the platform build process. Pre-generation of code may be useful for 
some clients, such as embedded devices, where certain XML schemas are already known. 
In one embodiment, some or all of the code doesn*t actually. have to be generated at all. A 
private code-loading scheme (within the client) might be used in one embodiment to 
augment the generation process. In addition, the distributed computing environment may 
specify, in some embodiments, an interface to download code for additional features in 
accessing a service (see, e.g., message conductors described below). Typically, such 
downloaded code may be small and the client may have the option to download the code 
or not. 

The phrase "generated code" may refer to code that originates within the client 
under the control of the client code execution environment, or to code that is generated 
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elsewhere (such as on the service system or on a space service system) and that may be 
downloaded to the client system after generation. Binding time, however, may be at 
runtime. At runtime, the generated code may be bound to a service address (URI), so that 
a message may be sent to that service instance. 

As discussed above, the interface to any service in the distributed computing 
environment may be specified by an XML schema, defining the set of messages that a 
client may send (and receive from) that service. As illustrated in Figure 10, the client 110 
and service 112 may each construct a message gate 130 for conrmiunicating according to 
the specified XML schema. From the XML schema advertised for the service 112 (and 
possibly other information in the service advertisement), a message gate 130a or 130b 
may be constructed by the client 110a or UOb respectively. A corresponding message 
gate 130c generated from the same XML schema may also exist on the service 112a. A 
gate 130 is a message endpoint that may send and/or receive type-safe XML messages, 
and that may verify the type correctness of XML messages when sending and/or receiving 
the messages. The message gate may also provide for authentication and/or other security 
mechanisms to ensure that the message endpoint is secure. In one embodiment, message 
gates are always secure. 

The distributed computing environment messaging layer described above may be 
coupled to or may be part of the gate. The messaging layer asynchronously delivers an 
ordered sequence of bytes, using a networking transport, from the sender to the receiver, 
maintaining the notion on both the sender and receiver that this sequence of bytes is one 
atomic unit, the message. The distributed computing environment does not assume that 
the networking transport is IP-based. Instead, the messaging layer may sit atop whatever 
networking transport layer is supported by the device. 

Message gates may provide a mechanism to send and receive XML messages 
between clients and services. The XML messages may be "typed". For example, the 
messages may include tags to indicate if a message data field is, e.g., integer, floating 
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point, text data, etc. A message gate may be constructed to verify the type correctness of 
messages sent or received. A message gate also may authenticate (e.g. securely identify) 
the sender of a received message. An XML schema may be provided for a service that 
describes the set of messages accepted by the service and/or sent by the service. A 
message gate may verify the correctness of messages sent or received according to the 
XML schema for which the gate is constructed. 

A gate may be constructed as a single atomic unit of code and data that performs 
type verification and/or message correctness verification and/or sender identification for 
messages between a client and a service in the distributed computing environment. In 
one embodiment, once the atomic unit of code and data for a message gate has been 
created, it cannot be altered as to its typing, message descriptors, and sender 
identification. In another embodiment, the gate may be modified as to the contents of the 
message schema after the gate is created, including deleting, adding, or modifying 
messages in the message schema. 

A message gate is the message endpoint for a client or service in the distributed 
computing environment. A message gate may provide a secure message endpoint that 
sends and receives type-safe XML messages. Messages gates may allow clients and 
services to exchange XML messages in a secure and reliable fashion over any suitable 
message transport (e.g. HTTP). For a client, a message gate may represent the authority 
to use some or all of a service's capabilities. Each capability may be expressed in terms 
of a message that may be sent to a service. Each such message may be sent through a 
client message gate which may verify the correctness of the message. The message may 
be received by a service message gate which may authenticate the message and verify its 
correctness. 

A message gate may provide a secure communication endpoint that type checks 
XML messages. As further discussed below, a message gate may also provide a 
mechanism to restrict the message flow between clients and services. In one embodiment 
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when a client desires to access a service, a client and service message gate pair is created, 
if not already existing. In one embodiment, the service message gate may be created 
when the service receives a first message from the client message gate. In one 
embodiment, one or more service message gates may be created when the service is 
5 initialized, and may be used to pair with client message gates when created. The creation 
of a message gate may involve an authentication service that may negotiate the desired 
level of security and the set of messages that may be passed between client and service. 
In one embodiment, the authentication service may accept a client ID token (also referred 
to as a client token), a service ID token (also referred to as a service token), and a data 
10 representation language message schema that describes the set of data representation 
language messages that may be sent to or received from the service. For example, 
^ messages may be described that may be sent from a client to a service to invoke the 

^ service or to invoke aspects of the service. Messages may also be described that are to be 

sent from the service, such as response messages and event notification messages. Refer 



15 to the Authentication and Security section below for a further discussion of how the 



authentication service may be used in the construction and use of message gates. 



A client message gate and a service message gate pair may allow messages to be 
sent between the client and the service. In one embodiment, message gates may be 

20 created that only send and/or receive a subset of the total set of messages as described in 
the message schema for a service. This limited access may be used within the distributed 
computing environment to implement a policy of least privilege whereby clients are only 
given access to specific individual message types, based on a security policy. Refer to the 
Authentication and Security section below for a further discussion of security checks for 

25 gate usage and gate creation. 



Client and service gates may perform the actual sending (and receiving) of the 
messages from the client to the service, using the protocol specified in the service 
advertisement (URI of service in the service advertisement). The client may run the 
30 service via this message passing. A message gate may provide a level of abstraction 
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between a client and a service. A client may access a service object through a message 
gate instead of accessing the service object directly. Since the gate abstracts the service 
from the client, the service's code may not need to be loaded, and then started, until the 
client first uses the service. 

The client gate may also perform verification of the message against the XML 
schema, or verification of the message against the XML schema may be performed by the 
service gate, e.g. if the client indicates it has not yet been verified. In some embodiments, 
verification may not be practical for simple clients and may thus not be required at the 
client. In some embodiments, verification may be performed by the service. The gates 
may also perform authentication enablement and/or security schemes. In one 
embodiment, if a client does not support the protocol specified in the service 
advertisement, then it may not be able to construct the right gate. To avoid this problem, 
service advertisements (used for gate construction) may include a list of possible URIs for 
a service, so a variety of clients may be supported. 

A basic message gate may implement an API to send and receive messages. The 
API moves data (e.g. XML messages) in and out of the gate, validating messages before 
sending and/ or upon receiving. In one embodiment, message gates may support a fixed 
minimum API to send and receive messages. This API may be extended to other features 
as discussed below. As illustrated in Figure 10b, a gate 130 may be generated according 
to an XML schema 132. The generated gate code verifies messages based upon the XML 
schema. The gate may verify correct message types and/or content through the message 
API. As illustrated in Figure 10b, through the message API a verified message may be 
sent to a service. The message may be received by a corresponding gate at the service. In 
response to the message, the service may generate results 180. The service may return 
result data 182 through its gate. The results data may be the results themselves or a 
reference to the results, such as a URI to results stored in a space.. In various 
embodiments, the message API may support synchronous messages (request-response), 
asynchronous messages (response is disconnected from request), unicast messages (point 
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to point), multi-cast messages (broadcast), and publish and subscribe (event messages), 
for example. Other type of messages may also be supported, such as remote method 
invocation messages. 



5 Each message sent by a gate may include an authentication credential so that the 

receiving gate may authenticate the message. Each message may also include a token 
which includes information allowing the receiving gate to verify that the message has not 
been compromised or altered. For example, the sender may compute a hash or checksum 
of the message which may be verified by the receiver. The sender may also encrypt this 
10 token and/or the entire message using the sender's private key and may include in the 
encrypted message the corresponding public key so that the receiver may verify that the 
_ token was not changed. See the section below on Authentication and Security. 

'^n A pair of message gates may provide a mechanism for communicating requests 



I . I 
Ol 



15 from clients to services and response from services to clients. Two associated message 



gate endpoints may be used to create a secure atomic bi-directional message channel for 
s request-response message passing. Thus, the distributed computing environment may 

^ employ a message transport in which a message gate exists on both the client and the 

service sides. The two gates may work together to provide a secure and reliable message 
20 channel. 

Turning now to Figure 11a, an illustration is provided for one embodiment 
showing construction of a gate 130a in a client 110 from a service advertisement or other 
service description 132. The client may have a gate factory 140 that is trusted code on the 
25 client for generating gates based on XML service descriptions. The use of the gate 
factory 140 may ensure that the gate it generates is also trusted code, and that the code is 
correct with respect to the service advertisement. As shown in Figure lib, a gate 130c 
may also be constructed at a service 112. The client gate 130a and the service gate 130c 
provide message endpoints for communications between the client and service. In one 
30 embodiment, the pieces the gate factory needs to construct a gate 130 are the XML 
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schema of the service (from the service advertisement) and the URI of the service (from 
the service advertisement). In another embodiment, an authentication credential may also 
be obtained and used in gate construction by running an authentication service specified 
in the service advertisement. 

5 

A gate factory may provide a trusted mechanism to create message gates. In some 
embodiments, in order to ensure that a message gate is a trusted message endpoint, the 
code used to create the gate must be trusted code. A gate factory 140 may be a trusted 
package of code that is used to create gates. In one embodiment, each client and service 
10 device platform that desires to send and receive messages in the distributed computing 
environment may have a gate factory. In some embodiments, gates may be pre- 
constructed by a separate gate factory so that a device with pre-constructed gates may not 



need a full gate factory, or may include a partial gate factory for binding a service URI 

01 

iQ and/or an authentication credential to the pre-constructed gate at runtime (e.g. when 

I J I 

™ 15 messaging is desired). 

m 

a A gate factory for a device may generate gate code that may incorporate the 

language, security, type safety, and/or execution environment characteristics of the local 
^ device platform. By constructing gates itself, a device has the ability to ensure that the 

O 20 generated gate code is bug-free, produces only valid data, and provides type-safety. An 

advantage of a device generating its own gate code as opposed to downloading code for 
accessing a service is that the client code management environment has the control. The 
generated code may conform to the client's code execution environment (e.g. Java, C++, 
Smalltalk), as well as its management and security framework (Web-server and/or 
25 operating system). Generated code is also trusted code, because the client's runtime 
environment was involved in its creation. Trusted security information therefore may 
also be added by the trusted generated code. Thus, a device may receive an XML 
message schema for a service and then construct a gate based on that schema to access the 
device. The XML schema may be viewed as defining the contract with the service and 
30 the generated gate code as providing a secure way to execute the contract. Note that open 
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devices, in which un-trusted (e.g. downloaded) code may be run, may be configured so 
that gates may be generated only by trusted code. Open devices may employ a process 
model in which gates are enclosed in a protected, isolated code container that is not 
accessible to tools, such as debuggers, capable of discovering the gate's implementation, 
5 especially the gates authentication credential. 

A gate factory 140 may negotiate on behalf of a client with a service to create a 
gate to send messages to the service. Similarly, a gate may be constructed at the service 
to receive messages from the client gate and send messages to the client gate. Together, 
10 the client and service gates may form a secure bi-directional communication channel. 



yi 



^ A gate factory may provide a level of abstraction in gate creation. For example, 

when a client desires to use a service, instead of the client directly creating a gate to 
access the service, the gate may be created by a gate factory as part of instantiating the 
15 service. 



The gate factory may create or may include its own trusted message gate that is 
used to communicate with an authentication service (e.g. specified by a service 
advertisement) to receive an authentication credential for the gate being constructed. For 

20 services that do not restrict access, a gate may be constructed without an authentication 
credential. The gates for such services may not need to send an authentication credential 
with each message since the service does not restrict access. The authentication service is 
an example of a service that does not restrict access, in one embodiment. Thus, a gate 
factory may be configured to optimize gate construction by checking whether a service 

25 restricts access. If the service does not restrict access, then the gate factory may avoid 
running an authentication service as part of gate construction and may avoid included 
provisions for an authentication credential as part of the constructed gate. The gate 
factory may also receive or download an XML message schema (e.g. specified by a 
service advertisement) to create a gate matching that schema. The gate factory may also 
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receive or download a URI for the service and/or for a service message gate for use in 
creating the client message gate to communicate with the URL 

In addition, another gate construction optimization may be employed for certain 
clients that do not desire to perform checking of messages against a service's XML 
schema. The client may be too thin to perform the checking or may rely on the service 
gate to perform the checking or may simply choose not to perform the checking (e.g. to 
reduce gate memory footprint). The gate factory may be configured to receive an 
indication of whether or not a gate should be constructed to verify messages against the 
provided XML schema. In some embodiments, certain clients may have a gate factory 
that does not provide for message verification against a schema for its constructed gates. 
In some embodiments, gates may be pre-constructed not to verify messages. In some 
embodiments, a gate may be constructed to verify outgoing messages only, or verify 
received messages only. Thus, in some embodiments, a client may avoid or may chose to 
avoid building some or all of the gate code that checks the messages against the XML 
schema. 

In some embodiments, devices may maintain a cache of gates to avoid 
constructing them each time the same service is run. For example, when a new gate is 
constructed by a gate factory, the gate may be maintained in a gate cache. When the gate 
is no longer being used, it is kept in the gate cache instead of being deleted. If the gate 
cache becomes full, one or more gates may be removed from the gate cache according to 
a cache replacement algorithm, such as least recently used. When the gate factory is 
called to construct a gate, it first checks the gate cache to see if a matching gate already 
exists so that construction of a new gate may be avoided. 

The building of a gate may be made lightweight by appropriate reuse of pieces 
used to construct other gates. Certain portions of each gate may be the same, and thus 
may be reused from gate to gate, such as parts of the message verification code. Also, for 
some devices, conmion gate code may be built into the system software for the device and 
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shared by all gates on that device. Thus, the gate factory may avoid rebuilding this 
common code for each gate. Instead, the gate factory may simply bind the gate to this 
system software portion. For example, a system software portion may be provided to 
handle the message layer over whatever transports are provided on the device. 

Space services in particular may be good candidates for many of the gate 
construction optimizations described above since a service gate constructed for a space 
service may perform many of the same functions as other service gates for that space 
service. Refer to the Spaces section below for more information on space services. 

In some instances, a more efficient form of method invocation may exist. For 
example, if the target service runs in the same Java Virtual Machine as the client 
application, a more efficient form of method invocation may be to create a Java dynamic 
proxy class for the service. In such a case, a java.lang.reflect.Method invocation may be 
faster than sending a message. A gate binding time procedure may check for such an 
optimization and use it instead of running the gate factory to create a gate or bind an 
existing gate. 

In one embodiment, such as for special-purpose clients or small embedded 
devices, the generation of gate code at runtime may not be desirable due to memory 
consumption and code generation time. Thus, instead of having a gate factory that 
generates gates at runtime, in some embodiments gates may be pre-generated and built 
into the device. For example, message gates may be generated during the build of 
embedded software as a means of including a built-in secure message endpoint that does 
not have to be constructed at runtime. Thus, a client with built-in gates may not need a 
full gate factory, or may require only a partial gate factory for performing certain runtime 
binding to a built-in gate, such as for the URI and/or authentication credential. 

A generation tool may be provided for the pre-construction of gates. The 
generation tool may include an XML parser, a code generator and a code compiler. In 
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one embodiment, the code generator may be a Java source code generator and the code 
compiler may be a Java code compiler. During the build of the software for which built- 
in message gates is desired, the generation tool is run with input from all the relevant 
XML schemas for which gates are desired. 

As an example, if it is desired for a device to have a built-in message gate that can 
send and receive messages from a digital camera, the build of the device software may 
include running the gate generation tool with the camera's XML message schema as 
input. The XML schema may be parsed by the XML parser that may convert the XML 
schema into an internal form suitable for quick access during a message verification 
process. The tool's code generator may provide source code for a gate corresponding to 
the camera's schema. In some embodiments, the generation tool may also compile the 
source code and the gate code may be linked into the software package for the device. At 
runtime, the camera service may be discovered in the distributed computing environment. 
The message URI for the camera service may be bound to the built-in gate for the camera 
within the device. The binding of the URI to the pre-constructed gate may be performed 
by a gate constructor within the device. This gate constructor may be a much smaller, 
simpler gate factory. When the camera service is instantiated, the URI for the camera 
service is passed to the gate constructor as an XML message. The gate constructor may 
then bind the URI to the pre-constructed gate. 

Thus, a gate may be partially or fully generated at runtime, or a gate may be pre- 
generated before runtime with a binding process (e.g. for a URI or credential) performed 
at runtime. In one embodiment, a gate generation tool such as the gate factory or the 
generation tool for pre-constructed gates may be a Java-based tool to provide some level 
of platform independence. Alternatively, gate generation tools may be provided in any 
language, such as the native code for a particular device in the distributed computing 
environment. 
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Note that the distributed computing environment does not preclude a device from 
downloading part or all of a gate's code. For example, in some embodiments, a service 
may provide gate code that may be downloaded by a client wishing to access that service. 
However, downloaded code may present size, security and/or safety risks. 

A more detailed illustration of possible gate components for one embodiment is 
shown in Figure 12. A gate may include its address (or name) 150, a destination gate 
address 152, a valid XML schema (or internal form thereof) 154, and a transport URI 
153. In other embodiments, a gate may also include an authentication credential 156. 
Some gates may also include a lease 158 and/or a message conductor 160 to verify 
message ordering. 

A gate^s name 150 may be a unique ID that will (for the life of the gate) refer only 
to it. A gate may be addressed using its gate name 150. In one embodiment, gate names 
may be generated as a combination of a string from an XML schema (e.g. from a service 
advertisement) and a random number, such as a 128-bit random number. The name 150 
may allow clients and services to migrate about the network and still work together. In a 
preferred embodiment, the gate address is independent of the physical message transport 
address and/or socket layer. Thus, a gate name may provide a virtual message endpoint 
address that may be bound and un-bound to a message transport address. In one 
embodiment, a gate's name may be a Universal Unique Identifier (UUDD) that may, for 
the life of the gate, refer only to it. 

A gate name may persist as long as the gate persists so that different applications 
and clients executing within the same device may locate and use a particular gate 
repeatedly. For example, a gate may be created for a first client process executing within 
a device to access a service. After the first client process has completed its activity with 
the service, it may release the gate. Releasing the gate may involve un-binding the gate 
from the first client process's message transport address (e.g. IP and/or Port address). 
The gate may be stored in a gate cache or repository. A second client process executing 
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within the same device that desires to run the same service may locate the gate by its 
name and use it to access the service. To use the gate, the second client process may bind 
the gate to its message transport address, so that the message endpoint for the second 
client process is a combination of the gate name and the second client process's transport 
address. In another example, a client may receive a dynamic IP address (e.g. a mobile 
client). When the client's transport address changes, a gate name (or gate names) may be 
re-bound to the client's new transport address so that the client may still access a 
service(s) that it previously accessed without having to relocate the service and recreate 
the gate. A gate name may also be useful for process migration. A process and any 
associated gates may be checkpointed or saved at one node in the distributed computing 
environment and moved to another node. The process may be restarted at the new node 
and the associated gates may be bound to the transport address for the new node so that 
the process will still have access to the external services to which it had access before 
being migrated. A gate may track the current location of another gate to which it is 
paired. Thus a service or client may be migrated and still be accessible. For example, 
replicated or load-balanced service implementations may be abstracted from clients of the 
service by the gate. 

Thus, a gate name 150 provides a flexible mechanism by which to address a 
message endpoint in the distributed computing environment. A gate name may be used to 
locate and/or address a gate over a wide range of networks, from a local network to the 
Internet. Gate names may be independent of message transport so that a message 
endpoint (gate) may be moved from transport to transport by unbinding and rebinding to 
different underlying transport addresses (e.g. IP/Port address pairs). 

In one embodiment, a gate may also be separated from a service so that the same 
gate may be used to send requests to different services over time. This may involve un- 
binding the gate's destination gate address 152 and binding a new destination gate 
address to the gate. 
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A gate may be implemented as a layer above a device's transport layer (e.g. 
networking sockets). Each gate may include a transport reference 153. The gate name 
150 may be bound to the transport reference 153 as described above. Multiple gates may 
share the same message transport. For example, multiple gates may have transport 
references 153 to the same TCP/IP socket. By sharing the same message transport, the 
size and complexity of each gate may be reduced. A device in the distributed computing 
environment may have a large number of gates that need to send and receive messages. 
The message handling complexity for multiple gates may be reduced by sharing a 
common message transport. The transport reference 153 may be a transport URI (e.g. 
URL) or socket reference and may provide a mechanism for naming an underlying 
transport and sharing the transport with other gates. Multiple local gates may include a 
reference 153 to the same transport, however, each local gate may behave independently 
of the other local gates sending and receiving messages to and from its paired remote 
gate. 

The schema 154 may be downloaded from a space into the gate by the gate 
factory. The schema may be compiled into an internal form suitable for quick access 
during a message verification process. In one embodiment, the schema may specify two 
groups of messages: client service messages and provider service messages. The cHent 
service messages group includes the description of all messages that the client may send 
(that the provider supports), and the provider service messages group includes the 
description of all messages that the provider may send (that the client receives). In one 
embodiment, either the client or provider may send a particular request to the space 
service to obtain a response message with either: the entire client service messages, the 
entire provider service messages, the entire client and provider service messages, or a 
specific message of either the client service messages or the provider service messages. 
In addition, once a gate has been constructed, a client may query as to the capabilities of 
the service without the gate actually sending a message, but instead by inspecting the 
gate's set of messages. 
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As described above, a message gate may verify the sender of the message using an 
authentication credential, message content for type safety and according to an XML 
schema. However, it may also be desirable to verify that messages are sent between a 
client and a service in the correct order. It may be desirable to be able to provision 
applications (services) for clients to run without any pre-existing specific functionality 
related to the application on the client (e.g. no GUI for the application on the client). For 
example, a Web browser may be used on a client as the GUI for a service instead of 
requiring an application-specific GUI. Of the possible messages in the XML schema, the 
client may need to know what message next to send to the service. It may be desirable for 
the client to be able to determine which message to send next without requiring the client 
to have specific knowledge of the service. In one embodiment, the service may 
continually send response messages indicating the next input it needs. The service would 
then accept only the corresponding messages from the client with the requested input 
specified. Other ad hoc scheme for message ordering may also be employed. 

In another embodiment, a message conductor 160 may be employed in the gate or 
associated with the gate to verify the correct sequence of messages, as opposed to 
verifying each message's syntax (which may already be performed in the gate according 
to the schema). Message conductor 160 may provide a more general approach for 
application provisioning. The message conductor 160 may be specified in a service's 
advertisement. The message conductor indication in a schema may allow code to be 
generated on or downloaded to the client during gate construction, which may provide the 
choreography needed to decide which message to send next to the service. A message 
conductor may be implemented as a Java application, a Java Script, WML script, or in 
other progranmiing or scripting languages. 

In one embodiment, the message . conductor may accept as input an XML 
document (e.g. from a service advertisement) that presents the valid order or 
choreography for messages that may be sent between a client and the service. This XML 
document may also specify user interface information and other rules. The conductor 
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may parse this XML document into an internal form and enforce message ordering 
(and/or other rules) according to the enclosed ordering information. The conductor may 
prevent messages from being sent out of order. Or, if a message is sent out of order, an 
exception may be raised within the sending device. If a message is received out of order, 
the conductor may send an automatic response message back declaring the ordering error. 
The sender may then resend messages in the correct order. Note that in some 
embodiments, part or all of a conductor may be shared by several gates. Thus, a 
conductor may be linked to multiple gates. 

In one embodiment of a distributed computing environment, front ends for 
services (service interfaces) may be built in to clients. In one embodiment, the service 
interface may be a preconstructed user interface provided to the client by the service. In 
one embodiment, the service interface may be provided to the client in the service 
advertisement. The service interface may interact on the client with the user of the 
service to obtain input for running the service, and then may display results of running the 
service on the client. A "user" may be a human, embedded system, another client or 
service, etc. In one embodiment, a client device may not be able to provision arbitrary 
services, as the client device may only be able to run services for which it has a front end 
built in. In one embodiment, a service interface for a service may be implemented in a 
Web browser on the client. 

In one embodiment, a message conductor and/or service interface may be external 
to the gate and thus abstracted from the gate and client. The abstracted message 
conductor may provide provisioning of arbitrary services to any client device. In one 
embodiment, the message conductor may be written in code that may run on substantially 
any platform. In one embodiment, the message conductor may be written in the Java 
language. In one embodiment, the message conductor may not require the arbitrary 
downloading of objects, for example, Java objects, returned to the client device. For 
example, very large objects may be returned, and the message conductor may choose to 
not download these very large objects. In one embodiment, the message conductor may 
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send XML messages to services from the client device on behalf of the client. The 
message conductor may interact with the user of the service to receive input and display 
results. 

In one embodiment, a service interface may be provided that interacts with the 
client (e.g. thru a user interface) to obtain all information to run the service, and then may 
display either results of running the service or information regarding the location of 
results, as appropriate. The service interface may be either part of a message conductor 
160 or may be in addition to and work with message conductor 160. The service 
interface may either be: 

1. Built in to the client device and thus run on the client. 

2. Downloaded to the client device from the space server. 

3. Run on the space server. 

4. Run on the service provider. 

In one embodiment, to a client, the distributed computing environment space server 
must support #1 always, indicate if #2 is supported (by advertisement in space), indicate 
if at least one of #3 and #4 is supported. Note that whether or not it supports #4 depends 
upon whether or not the service provider supports #4. In one embodiment, to a service 
provider, the distributed computing environment space server must support #4 always and 
indicate if it supports #3. 

Regardless of where the service interface runs, once a service is activated, the 
service interface may interact with the client, displaying (remotely) requests for input on 
the client's display, and then displaying (remotely) results of running the service. Such 
interaction with the client is implemented in terms of XML messages. 
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The service interface and/or message conductor may meet the needs of a client 
user that may have discovered a service, but does not want to read a typically large, dry 
computer manual to figure out how to use the service. As the service interface and/or 
message conductor interacts with the user to request all input that the service needs, they 
may even provide short descriptions of the input requested if the user requests it. Once 
the service interface has obtained the necessary information from the client, it may send 
XML messages to the service provider that runs the service. The ordering of the 
messages may be verified by the message conductor 160 in the gate. 

In a preferred embodiment, all messages flow through a gate. A gate may be 
configured to provide a flow control mechanism. For example, a service may need to 
handle a large amount of incoming and outgoing messages. Flow control may allow a 
service to keep up with high traffic volume. Gates may be configured to monitor 
messages for flow control tags. When a gate receives a message, it may examine that 
message for a flow control tag. The flow control tags may be XML tags. A message may 
include either an OFF tag or an ON tag, for example. If a received message includes an 
OFF tag, the receiving gate will stop sending messages to its paired destination gate. If 
the gate receives a message including an ON tag, it may resume sending messages. 

Thus, a service-side gate may monitor the use of its resources and trigger flow 
control if use of its resources exceeds a threshold. For example, a service may reduce its 
load by sending messages including OFF tags to one or more client gates. The client 
gates receiving the messages with OFF tags will stop sending messages to the service. 
Pending messages in the clients may be buffered or may be handled by internal flow 
control mechanisms. Once the service is able to handle more requests, it may send 
messages to one or more clients with ON tags so that the clients may resume sending 
messages. In other embodiments, other flow control tags may be supported in addition to 
or instead of ON and OFF. Other flow control tags may indicate to reduce message flow 
or that message flow may be increased. 
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Message gates may be configured to perform resource monitoring. For example, 
since all messages may flow through a gate, the gate may be configured to manage and/or 
track a client's use of a service (and possibly its associated resources such as memory or 
threads). A gate may be configured to track the activity of a software program, such as a 
client, by monitoring how much a resource, such as a service, is used or which and how 
many service resources are used. In one embodiment, a gate may generate or may 
facilitate generation of a client activity log. Each message and its destination or sender 
may be logged. 

A gate may also be configured to perform resource monitoring for flow control 
from the local (sending) side of a gate pair. If the client exceeds an allocated bandwidth 
of service (or resource) usage, the gate may automatically throttle back the flow of 
messages, for example. Thus, a client-side message gate may automatically trigger 
different flow control modes by monitoring the flow of outgoing messages. If the 
outgoing message flow exceeds a threshold, the gate may reduce or shut off its flow of 
outgoing messages. The threshold may be specified in a service's XML schema or 
advertisement. In some embodiments, the threshold may be specified only for messages 
using certain service resources or for all messages. 

The gate may also be configured to determine when message flow may be 
increased or resumed. In one embodiment, the gate may maintain a count of outgoing 
messages that have been sent without the matching reply (response) received. When 
matching responses are received by the client-side gate, the count of outstanding request 
messages may be decremented. When the counts decrements below a specified 
outstanding request message threshold, the gate may increase or resume sending new 
request messages. 

A gate may be configured to support message-based accounting and/or billing. A 
billing system may be implemented based upon the number and/or kind of messages sent 
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and/or received by a message gate. Since all messages to and from a client may pass 
through a gate, the gate may be configured to facilitate charging a client for service usage, 
for example on a per message basis or "pay as you go". Thus, a billing system may be 
implemented within the distributed computing environment in which a user could be 
charged, for example, each time a message is sent and/or received by software running on 
behalf of the user. 

In one embodiment, a message gate may receive billing information from an XML 
schema, e.g. for a service. The billing information may denote a billing policy and a 
charge-back URL The charge-back URI may be used by the message gate to charge time 
or usage on behalf of a user. A message gate may make a charge-back by sending a 
charge message to the charge-back URI specified in the XML schema. Gates so 
configured may be referred to as bill gates. The billing policy may indicate charge 
amounts per message or per cumulative message totals, etc. The billing policy may 
indicate how much and/or how often (e.g. after every x number of messages sent and/or 
received) to charge the user. The policy may indicate that only certain types of messages 
trigger charges, such a messages requesting a specified service resource. The billing 
policy may also indicate different billing models for different clients or classes of clients. 
For example, a billing policy may be configured (e.g. in a service's XML schema) so that 
some clients may pay a one-time charge when they create a gate to access the service. 
The policy may indicate clients that are to pay as they go (e.g. per message), or may 
indicate clients that are not to be charged at all. 

In some embodiments, a client may be too thin to support a full gate, or a client 
may not include software to directly participate in the distributed computing environment. 
In such embodiments, a server (such as the space server in which the service is advertised 
or another server) may be a full or partial proxy gate for the client. The server may 
instantiate a service agent (which may include a gate) for each service to be used by the 
client. The service agent may verify permission to send messages; send messages to the 
provider, possibly queuing them until the provider can accept the next one; send 
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messages to the client, possibly queuing them until the client can accept the next one; and 
manage the storing of results in a result or activation space. See also the Bridging section 
herein. 

For example, as illustrated in Figure 13, a client may be a conventional browser 
400 that does not support gates to participate directly in the messaging scheme described 
above. The browser 400 may be aided by a proxy servlet (agent) 402. The browser user 
may use a search engine to find a Web page that fronts (displays the contents of) a space 
advertising services within the distributed computing environment. The user is able to 
point and click on the space Web page and, with the help of the servlet, to access 
services. The Web pages may include scripts, for example, Java or WML scripts, which 
may be used in connecting the browser to the proxy servlet. Scripts may also be used to 
send messages to the proxy servlet. The servlet agent may translate Web page actions 
into messages on behalf of the browser client. These actions may include navigating a 
space, starting services, and returning results. Result page URIs (referencing pages 
containing XML) may be returned directly (or translated into HTML or WAP if needed) 
to the browser, for display to the user. Thus, the browser-based client does not need to 
know how to start services, nor which messages to send during the service usage session. 
For example, a user of a WAP browser (e.g. on a cell phone) may connect to a space 
page, browse its contents (services), and then start a service, all by pointing and clicking. 
The agent 402 provides the client interface between the conventional client and the 
distributed computing environment. 

The distributed computing environment may include several different types of 
message gates for communicating between clients and services that support different 
features. For example, as discussed above, some gates may support flow control or 
billing. Another type of message gate may support a form of remote method invocation. 
This type of gate may be referred to as a method gate. 
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A gate is a secure message endpoint that sends and receives type-safe messages, 
e.g. XML messages. The remote method invocation (RMI) style gate may be referred to 
as a method gate. The direct data-centric gate may be referred to as a message gate. A 
method gate may be implemented as a "layer" on top of a message gate. The exact 
implementation may be defined in the platform binding. 

Figure 14 illustrates the use of a method gate to provide a remote method 
invocation interface to a service. Method gates provide a method interface between 
clients and services. A method gate may be bi-directional, allowing remote method 
invocations from client to service and from service to client. A method gate 172 may be 
generated from XML schema information 170 (e.g. from a service advertisement in a 
space). The XML schema information 170 includes XML defining a method interface(s). 
From this information, code may be generated as part of the gate for interfacing to one or 
more methods. Each method invocation (e.g. from a client application 176) in the 
generated code may cause a message to be sent to the service containing the marshaled 
method parameters. The message syntax and parameters to be included may be specified 
in the XML schema. Thus, the method gate 172 provides an XML message interface to 
remotely invoke a service method. The method gate may be generated on the client or 
proxied on a server, such as the space server where the service method was advertised or 
a special gateway server. 

A service may have a corresponding method gate that implements or is linked to a 
set of object methods that correspond to the set of method messages defined in the 
service's XML schema. There may be a one to one correspondence between the object 
methods implemented by or linked to the service's method gate and the method messages 
defined by the service's XML schema. Once a service's corresponding method receives a 
message from a client to invoke one of the service's methods, the service's method gate 
may unmarshal or unpack the parameters of the message invocation and then invoke the 
method indicated by the received message and pass the unmarshaled parameters. 
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The method gate may provide a synchronous request-response message interface 
in which cHents remotely call methods causing services to return results. The underlying 
message passing mechanics may be completely hidden from the client. This form of 
remote method invocation may deal with method results as follows. Instead of 

5 downloading result objects (and associated classes) into the client, only a result reference 
or references are returned in XML messages, in one embodiment. An object reference 
178 may be a generated code proxy (e.g. results gate) representing the real object result 
180 (still stored out on the net, for example). In other embodiments, the client may 
choose to receive the actual result object. In addition, once a client has received a result 

10 object reference, the client may use this reference to receive or manipulate the actual 
result object. In one embodiment, the result reference includes one or more URIs to the 
real result. 



The real result object(s) may be stored in a service results space (which may be 
15 created dynamically by a servlet, for example). This temporary results space may act as a 
query results cache. The results cache (space) may be patrolled by server software 
(garbage collector) that cleans up old result areas. Results returned from each method 
invocation may be advertised in the results space. A result itself may be or may include a 
method that could then be remotely instantiated by a client, thus generating its own 
20 method gate. Therefore, the distributed computing environment may support recursive 
remote method invocation. 



Results Gates 



25 As mentioned above, when a client uses a method gate to remotely invoke a 

service method, a reference to the method results may be returned from the service 
method gate instead of the actual results. From this reference, a results gate may be 
generated to access the actual result. Thus, the client or client method gate may receive a 
result URI and perhaps a result XML schema and/or authentication credential for 

30 constructing a gate to access the remote method results. 
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In one embodiment, a service gate may create a "child gate" for the results. This 
child results gate may share the same authentication credential as its parent gate. In some 
embodiments, results may have a different set of access rights and thus may not share the 
same authentication credential as its parent. For example, a payroll service may allow a 
different set of users to initiate than to read the payroll service's results (paychecks). 

A service method gate may return a child results gate to the client gate as the 
result of the method. The client may then use the results gate to access the actual results. 
In one embodiment, the software program (client) receiving the results gate cannot 
distinguish between the results gate and the result itself in which case the results gate may 
be an object proxy for the actual result object. The results gate may also be a method gate 
that supports remote method invocation to result objects. In this manner, a chain of 
parent and child method/results gates may be created. 

In one embodiment, the method gates and remote methods may be in Java. In this 
embodiment, method results are correctly typed according to the Java typing system. 
When a Java method is remotely invoked as described above, the results gate may be cast 
into the Java type that matches the result type. In this embodiment, method gates may be 
used in the distributed computing environment to allow remote Java objects to behave as 
local Java objects. The method invocation and results may appear the same to the client 
Java software program whether the real object is local or remote. 

Figure 49 is a flow diagram illustrating a mechanism for providing results gates 
according to one embodiment. Results gates may be provided to clients in the distributed 
computing environment and used by the clients to access results generated by services on 
behalf of the clients. A client may generate a request message for a service as indicated at 
1900. The request message may include information requesting the service to perform a 
function on behalf of the client. In one embodiment, the request message may be 
generated in response to a computer programming language (e.g. Java, C++, Smalltalk, 
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etc.) method call made by a client process. In this embodiment, the request message may 
be generated by a client method gate, and may include a data representation language (e.g. 
XML) representation of the method call. 

The client may send the message to the service as indicated at 1902. In one 
embodiment, the message may be sent by a client message gate. In another embodiment, 
the message may be sent by a client method gate. In yet another embodiment, the 
message may be generated by a client method gate, passed to a client message gate, and 
sent to the service by the client message gate. In one embodiment, an authentication 
credential may be attached to the message. In one embodiment, information may be 
attached to the message for use in verifying the message is not compromised during 
sending to the service (e.g. a hash of the message). 

The service may receive the message and generate results in response to the 
message as indicated at 1904. In one embodiment, a service message gate receives the 
message and provides request information to a service process, which then performs one 
or more functions that generate results. In another embodiment, the message includes a 
data representation language representation of a computer programming language method 
call. The data representation language representation of the method call may include an 
identifier of the method to be called and one or more parameters of the method call. In 
this embodiment, a service method gate may receive the message and regenerate the 
method call from the representation of the method call. A computer programming 
language method (e.g. Java method) may then be invoked using the method call. The 
invoked method may generate the results. 

The service may store generated results. The results may be stored locally (e.g. to 
a space service comprised on the service device) remotely (e.g. on a space service on a 
separate device). The service may then send an address (e.g. URI) of the results to the 
client. Alternatively, the service may return the results directly to the client in one or 
more messages. In one embodiment, the results may be comprised in a data 



Atty. Dkt. No.: 5181-66100 



Conley Rose & Tayon, P.C. 



: G 



u 



representation language document. In another embodiment, the results may be comprised 
in a data representation language representation of a computer programming language 
object (e.g. Java object). 

5 A results gate may be generated as indicated at 1906. In one embodiment, the 

results gate may be generated by the service and sent to the client. In another 
embodiment, the service may send an address of the results to the client, and the client 
may generate the results gate from information (e.g. an advertisement for the results) 
located through the address. In yet another embodiment, the service may send the results 
10 to the client, and the client may generate a results gate for the results. In one 
embodiment, a message schema may be provided in used in generating the results gate. 
The message schema may include information describing one or more data representation 
language messages for accessing the results. 

15 In one embodiment, a gate on the client may generate the results gate. In one 

embodiment, the gate may provide information to a gate factory, and the gate factory may 
generate the results gate. In one embodiment, the gate may be a method gate, and the 
results may have been generated in response to a computer programming language 
method performed by the service as indicated at 1904. In one embodiment, the results 

20 gate may share authentication information with the generating gate. For example, the 
gate may attach an authentication credential of the client to outgoing messages. The gate 
may provide the same authentication credential to the results gate for use in outgoing 
messages. 

25 The results may be accessed through the results gate as indicated at 1908. In one 

embodiment, the results are an object (e.g. Java object), and the results gate is an object 
proxy for the results object. In this embodiment, a client process (e.g. Java program) 
accessing the results object through the results gate may not be able to distinguish the 
results gate object proxy from the real results object. In other words, to the process, the 

30 object proxy provided by the results gate may appear the same as the actual results object. 
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In this embodiment, the results gate may be returned to the process as results of the 
method call made by the process. 

In one embodiment, the results gate is a method gate and provides a method 
interface to the results. In this embodiment, the results gate supports a set of method calls 
for accessing the results. When receiving a method call from a client process, the results 
gate may convert the method call into a data representation language representation of the 
method call and send the representation in a message to the results location (e.g. space 
service) where the method call may be regenerated and the method invoked with the 
method call. 

In one embodiment, a results gate may generate another results gate. For 
example, the results gate may generate a message to access the results, and may receive a 
response to the message. The results gate may then generate a second results gate 
subsequent to receiving the response as indicated in 1908. 

See the Spaces section below for a further discussion on the use of spaces for 

results. 

Method Gates 

Method gates provide a method interface to clients, instead of just a raw message 
interface. In one embodiment, a method gate may be implemented on top of a message 
gate. The message gate provides the method gate with transport access, message content 
validation, and message content access (get content and set content methods). In one 
embodiment, each method invocation in the generated code (i.e. method gate) causes a 
single synchronous message to be sent to the service containing the marshaled method 
parameters. The method gate may then causes the current thread to block, waiting for a 
response message from the service. 
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This style of programming may be referred to as synchronous request-response 
progranmiing. CHents call methods causing services to return results. The underlying 
message passing mechanics are completely hidden from the client. This form of RMI 
deals with method results in a unique and interesting way. In one embodiment, instead of 
downloading objects (and associated classes) into the client, only result object references 
(Advertisements or Advertisement URIs) are returned. In this embodiment, given an 
object reference, a results gate may be generated that gives access to the real object (still 
stored out on the net). 

In one embodiment, some results produced by a service are advertised in a space 
and ultimately accessed using a results gate. The results gate may or may not contain the 
same security credential as the input gate used to generate the results. Because input to a 
service is asynchronous from its output (the results), the results may have a different set 
of access rights associated with it. Using a B2B scenario, a payroll service may allow a 
different set of users to initiate payroll than to read the payroll service's results 
(paychecks). 

In one embodiment, results gate generation for message gate results may be 
manually initiated. In-line results (e.g. XML documents sent as a response from a 
service) can be accessed using the message content access (e.g. get and set) methods 
available on message gates. Method results gate generation may be automatically 
initiated. The method gate model of progranmiing hides results gate generation, creating 
a seamless, remote method invocation programming model without the overhead of class 
loading or requiring the application programmer to manually generate results gates. 

Figures 45a-45e are flow diagrams illustrating various embodiments of 
mechanisms for communicating between clients and services in a distributed computing 
environment using method gates. In Figure 45a, at 2100, a message including a 
representation of a computer progranmiing language (e.g. Java) method call may be 
generated on the client device. In one embodiment, the message may be in a data 
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representation language. In one embodiment, the data representation language is XML. 
In one embodiment, a client process may make a method call, and the method call may be 
marshaled into a representation of the method call included the message. The 
representation of the method call in the message may include, but is not limited to, an 
identifier (e.g. method name) that identifies the method call, and zero or more parameter 
values for the method call. The representation of the method may be in the data 
representation language. For example, the elements in the representation may be one or 
more tags (e.g. XML tags) in the message. 

In one embodiment, a method gate may access the method call generated by the 
client process, and then may marshal the method call into the message. In one 
embodiment, a message including a representation of a method call may be generated on 
the client when no actual method call was made. In this embodiment, a process on the 
client may invoke computer programming language methods on a service without actually 
generating computer programming language method calls. For example, a client may 
include one or more "canned" messages that the client may send to the service to invoke 
one or more methods of the service. Thus, the client may use messages to request the 
service to perform methods without a process on the client actually making a method call. 

At 2102, the client may send the message to the service. In one embodiment, the 
client method gate may send the message to the service. In one embodiment, the client 
method gate may send the message directly to the service. In another embodiment, the 
client method gate may provide the message to a client message gate, which may then 
send the message to the service. 

At 2104, after the service receives the message, a function may be performed on 
the service in accordance with the representation of the method call in the received 
message. In one embodiment, the service may unmarshal or unpack the method call from 
the received message, invoke the method indicated by the received message and pass the 
unmarshaled parameter values to the invoked method. In one embodiment, the 
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unmarshaling and invoking may be performed by a method gate on the service. In one 
embodiment, instead of invoking the method, the service may perform a function (e.g. 
other method or some other action) in response to the message. For example, the service 
may execute a function that generates the desired results of the method call without 
invoking a method on the service. In another example, the service may have previously 
generated results data for the method call, and may provide the results data to the client in 
response to the message without invoking the method. 

At 2106, the function on the service may generate results data in response to the 
message. At 2108, the results data may be provided to the client. In one embodiment, the 
results data may be returned directly to the client (e.g. in a message). In another 
embodiment, the results data may be stored in the distributed computing environment 
(e.g. on the service device, or on a space service external to the service device) and an 
advertisement may be provided to the client for accessing the stored results data. The 
client may then use the advertisement to set up a results gate for accessing the results 
data. In another embodiment, the service may return a results gate to the client for 
accessing the results data. 

In one embodiment, the client may transform a method call into one or more 
messages that may be sent to the service, wherein the messaged do not include 
information that may be unmarshaled into a method call, but instead include information 
that may be used by the service to perform a function on behalf of the client. In this 
embodiment, the service may not know that the messages were originally generated from 
a method call. In one embodiment, a client method gate may transform a method call 
generated on the client into one or more messages requesting the service to perform one 
or more functions for the client, but not including a marshaled method call that the 
service may unmarshal into a method call. These messages may still be considered a 
"representation" of the method call, but may not be in a form that the service recognizes 
as a marshaled method call that may be unmarshaled to regenerate the method call. 
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In one embodiment, the service may transform one or more messages requesting 
the service to perform one or more functions into a method call. In this embodiment, no 
method call may have been made on the client to generate the messages (the client may 
not have generated the one or more message in response to a method call). Thus, the 
client may not know that the service is invoking a method to perform the requested 
function(s). In one embodiment, a service method gate may receive the message(s) from 
the client and construct a method call from the information in the message(s). 

In Figure 45b, a client process executing within a client device may make a 
method call (i.e. invoke the method) at 2110. In one embodiment, the method call may 
be a call to a Java method. In one embodiment, the called method may not be 
implemented locally on the client device, but is implemented on a service device external 
to the client device. At 2112, a client method gate on the client device may receive the 
method call. The client method gate may then marshal the method call into a data 
representation language message. In one embodiment, the data representation language is 
XML. The message may include an identifier of the method and one or more parameter 
values of the method. The identifier may be a name, number, or other value used to 
identify the method to the receiver of the message. A method call may include one or 
more parameters, and when called, the caller supplies values for these parameters. In one 
embodiment, more than one method call may share the same identifier, and may be 
distinguished by the parameters of the method. 

At 2114, the client method gate may send the message to the service device. In 
one embodiment, the client method gate may send the message directly to the service 
method gate. In another embodiment, illustrated in Figure 45c, the client method gate 
may provide the message to a client message gate at 2124. The client message gate may 
then send the message to a service message gate at 2126. The service message gate may 
then provide the message to the service method gate at 2128. The embodiment illustrated 
in Figure 45c frees the method gates from the responsibility of handling the sending and 
receiving of messages, and simplifies the programming model of the distributed 
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computing environment by compartmentalizing the RMI functionality and the message 
handling functionality. 

In one embodiment, the client may attach a credential to the message for verifying 
the message (and client) on the service. In one embodiment, the credential may have 
been obtained by the client from an authentication service in the distributed computing 
environment. In one embodiment, the service may have provided information to the 
client identifying the authentication service to use (e.g. in a service advertisement). In 
one embodiment, the service may use the same authentication service to authenticate the 
client (e.g. when a first message is received from the client). The service may then check 
each message from the client to verify that the message includes the proper credential for 
the client. In one embodiment, the service method gate may perform the verification. In 
another embodiment, a service message gate may perform the verification, and may then 
pass the verified message to the service method gate. See the Authentication and Security 
section for more information on credentials and verification. 

Returning to Figure 45b, at 2116, the service method gate may unmarshal or 
unpack the method call from the received message, invoke the method indicated by the 
received message and pass the unmarshaled parameter values to the invoked method. 
The service method gate may use the identifier included in the message to locate the 
template for the method call. The service method gate may implement or may be linked 
to a set of methods that correspond to the set of method messages defined in the service's 
XML schema. There may be a one to one correspondence between the object methods 
implemented by or linked to the service's method gate and the method messages defined 
by the service's XML schema. In one embodiment, a method gate may be created on a 
client in accordance with a message schema provided to the client by the service, e.g. in a 
service advertisement. In one embodiment, a gate factory may be used to generate the 
method gate on the client. 
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At 2118, the invoked method may be implemented or performed on the service. 
At 2120, the invoked method may produce results output from the invocation in 
accordance with the parameter values received in the method invocation. At 2122, the 
results of the method invocation may be provided to the client process that originally 
invoked the method. In one embodiment, the service may direcdy provide the results to 
the client in one or more results messages. In another embodiment, the service may place 
the results in a space and may provide a results advertisement to the client for accessing 
the results. Figure 45d and 45e illustrate other embodiments where a results gate may be 
provided to the client for accessing the results. 

In Figure 45d, at 2130, the service method gate may provide a results reference to 
the service message gate. In one embodiment, the results reference may be an 
advertisement to the results. In another embodiment, the results reference may be an 
address, e.g. a URI, for the results. At 2132, the service message gate may send the 
results reference to the client message gate in a message. At 2134, the client, after 
receiving the message, may create a results gate from the results reference message. For 
example, a results advertisement may be provided in the message, and the client may 
create the results gate in accordance with the results advertisement in a similar manner to 
creating message gates from advertisements as described elsewhere herein. At 2136, the 
client may use the results gate to access the results. For example, the results may be on 
the service device, and the service may have generated a service results gate. The client 
results gate may be generated to communicate with the service results gate, e.g. the URI 
of the service results gate may have been included in the results advertisement. 
Alternatively, the service may have stored the results elsewhere in the distributed 
computing environment and the client results gate may be configured to communicate 
with a results gate set up for the results. For example, the results may be on a space, and 
the client results gate may communicate with a results gate on the space. 

In Figure 45e, the service may create a results gate at 2140. The service may then 
send the results gate to the client (in a message) at 2142. The received results gate may 
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then be used by the client to access the results. This embodiment frees the client from the 
responsibility of setting up the results gate. 

To the client process that originally invoked the method, the process of RMI as 
described herein is transparent. To the client process, it appears as if the method is being 
invoked locally, and that the results are being provided locally. Thus, the method gates, 
in combination with the message passing mechanism, may allow "thin" clients to execute 
processes that would otherwise be too large and/or complex to execute on the clients. 

A Java platform method gate implementation example follows. The actual Java 
method gate implementation for any Java platform is defined in the distributed computing 
environment platform binding. Each Java method gate granting access to a result is 
actually a Java class instance (an object) that implements the result's interface. For 
example, if the result were an object of type Table, the result method gate class may be 
defined as follows: 

public class TableMethodGate implements Table { 
public Cell getNextCellO; 

} 

The TableMethodGate object is cast to type Table before being returned as the 
method invocation result. The process is recursive. That is, when the getNextCell method 
is invoked, a CellMethodGate class and object instance are generated to represent the 
getNextCell result: 

public class CellMethodGate implements Cell { } 

The choice of which gate type (message or method) to use with a particular 
service is addressed in combination by the platform binding and each service 
advertisement. Some platforms may not support method gates. If a platform does support 
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method gates, the binding nnay define its precise implementation. Secondly, a service 
advertisement's interface may or may not lend itself to RMI-style programming. Those 
service interfaces that do support a RMI-style progranmiing model are flagged with the 
following XML attribute: 

<MethodGateInterface=true> 

Message gates may also support publish and subscribe message passing for 
events. Message gates with event support may be referred to as event gates. A service's 
XML schema may indicate a set of one or more events that may be published by the 
service. An event gate may be constructed from the XML schema. The event gate may 
be configured to recognize some or all of the set of events published by a service, 
subscribe to those events, and distribute each event as the event is produced by the 
service. 

Note that any combination of the gate functionality described above may be 
supported in a single gate. Each type has been described separately only for clarity. For 
example, a gate may be a message gate, a method gate and an event gate, and may support 
flow control and resource monitoring 

Service Discoverv Mechanisms 

In one embodiment, the distributed computing environment may include a service 
discovery mechanism that provides methods for clients to find services and to negotiate 
the rights to use some or all of a service's capabilities. Note that a space is an example of 
a service. The service discovery mechanism may be secure, and may track and match 
outgoing client requests with incoming service responses. 
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A service discovery mechanism may provide various capabilities including, but 
not limited to: 

• Finding a service using flexible search criteria. 

• Requesting an authorization mechanism, for example, an authentication 
credential, that may convey to the client the right to use the entire set or a subset 
of the entire set of a service's capabilities. 

• Requesting a credential, document, or other object that may convey to the client 
the service's interface. In one embodiment, the service's interface may include 
interfaces to a requested set of the service's capabilities. 

• The tracking of discovery responses to the original requests. In one embodiment, 
each client request may include a collection of data that may also be returned in 
matching responses, thus allowing the requests and responses to be correlated. 

In one embodiment, a distributed computing environment may include a 
mechanism for clients to negotiate service access rights. In one embodiment, the 
mechanism may be used to negotiate for a subset of a service's full capabilities. The 
result of the negotiation may be an authorization such as an authentication credential that 
conveys to the client the right to use the requested subset of the service's capabilities. 

In one embodiment, the service discovery mechanism may allow a client to 
request a security capability credential from a service. In one embodiment, the client may 
present to the service a set of desired capabilities in the form of a protected (secure) 
advertisement. The service may then respond with a capability credential that may 
convey to the client the rights to use the requested capabilities described in the protected 
advertisement. 

In one embodiment, the distributed computing environment may include a 
mechanism for a client to negotiate service access rights and to then obtain a security 
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credential or document that may be used to present the service's access interface to the set 
or subset of the service's capabilities that were requested by the client. 

In one embodiment, a client that receives a capability credential from a service 
may generate a custom service access interface document that may be referred to as a 
"complete advertisement." In one embodiment, the complete advertisement may be an 
XML document. The generated advertisement may provide access to the service 
capabilities as granted to the client by the received capability credential. In one 
embodiment, an interface may be provided by the advertisement only to the service 
capabilities to which the client has been granted access by the capability credential. In 
one embodiment, the client may be granted access to only required capabilities and to 
which the client has access privileges. 

In one embodiment, the distributed computing environment may provide a 
mechanism by which a client may negotiate capabilities with services. In one 
embodiment, the client may negotiate its capabilities to the service. The service may then 
customize results based on the parameters negotiated with the client. For example, a 
client that is capable of one bit display at a resolution of 160x200 may negotiate these 
parameters to the service, thus allowing the service to customize results for the client. 

The distributed computing environment may include a mechanism that may allow 
clients to negotiate how a service is to return results of a service invocation. In one 
embodiment, during a capability credential request, a means by which to choose one of 
the results return methods may be conveyed to the service. The service may then generate 
a custom service advertisement that may convey to the client the results mechanism to be 
used, as well as the service interface. 

Matching Component (Service) Interfaces 
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The distributed computing environment may provide a mechanism for matching a 
component (for example, a service) specification interface with a requested interface. For 
example, a client (which may be a service) may desire a service that meets a set of 
interface requirements. Each component may have a description of the interface to which 
it conforms. The specification interface matching mechanism may allow a component 
that best matches a requestor's interface requirements to be located. The specification 
interface matching mechanism may also allow for "fuzzy" matching of interface 
requirements. In other words, the mechanism may allow matching without requiring the 
exact specification of all aspects of the interface, thus providing a nearest match (fuzzy) 
mechanism. In one embodiment, the specification interface matching mechanism may be 
implemented as a multi-level, sub-classing model rather than requiring specification at a 
single interface level. 

Using the specification interface matching mechanism, a basic desired interface 
may be compared to a set of component' interface descriptions. One or more 
components matching the basic desired interface may be identified. The interface 
descriptions may include subclass descriptions describing more specifically the interfaces 
provided by the components. In the search process, the class type hierarchy may be 
examined to determine if a given class is a subclass of the search type. In one 
embodiment, subclasses may inherit properties of the base class, and thus the subclass- 
specific information may not be examined in this phase. Thus, the search may be 
performed generically. The identified components may be searched at the next (subclass) 
level. The search may become specific to the subclass and may be performed by 
interpreting the subclass information included in the interface description. The search 
may continue through one or more subclasses until one or more components is 
determined which may provide the nearest match to the requestor's desired interface. 

Spaces 
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As mentioned above, the distributed computing environment relies on spaces to 
provide a rendezvous mechanism that brokers services or content to clients. Figure 15 
illustrates the basic use of a space 114. Service providers may advertise services in a 
space 114. Clients 110 may find the advertisements in a space 114 and use the 
information from an advertisement to access a service using the XML messaging 
mechanism of the distributed computing environment. Many spaces may exist, each 
containing XML advertisements that describe services or content. Thus, a space may be a 
repository of XML advertisements of services and/or XML data, which may be raw data 
or advertisements for data, such as results. 

A space itself is a service. Like any service, a space has an advertisement, which 
a client of the space must first obtain in order to be able to run that space service. A 
space's own advertisement may include an XML schema, a credential or credentials, and 
a URI which indicate how to access the space. A client may construct a gate from a space 
service's advertisement in order to access the space. A client of a space may itself be a 
service provider seeking to advertise in that space or modify an existing advertisement. 
Or a client of a space may be an application seeking to access a service or content listed 
by the space. Thus, spaces may provide catalysts for the interaction between clients and 
services in the distributed computing environment. 

A space may be a collection of named advertisements. In one embodiment, 
naming an advertisement is the process of associating a name string with an 
advertisement. The association may take place upon storing an advertisement in a space. 
Removing an advertisement from a space disassociates the name from the advertisement. 
A space may be created with a single root advertisement that describes the space itself. 
Additional advertisements may be added to a space. An advertisement's name may locate 
the advertisement within the space, including specifying any necessary graphing 
information such as a hierarchy of names. In a preferred embodiment, the structure of a 
space is not dictated by the distributed computing environment. That is, spaces may be 
structured as, for example, a flat un-related set of advertisements or a graph of related 
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advertisements (e.g. commercial database). Since, in a preferred embodiment, the 
distributed computing environment does not dictate how a space actually stores its 
content, spaces may be supported by small to large devices. For example, a simple space 
may be tailored to fit on small devices, such as PDAs. More advanced spaces may be 
implemented on large severs employing large commercial databases. 

As mentioned above, a space may contain advertisements for services in the 
distributed computing environment. An advertisement may provide a mechanism for 
addressing and accessing services and/or content within the distributed computing 
environment. An advertisement may specify a URI for a service. In some embodiments, 
the URI may allow for the service to be accessible over the Internet. An advertisement 
may also include an XML schema for the service. The XML schema may specify a set of 
messages that clients of the service may send to the service to invoke functionality of the 
service. The XML schema may define the client-service interface. Together, the URI 
and the XML specified in an advertisement may indicate how to address and access the 
service. Both the URI and schema may be provided in XML as an advertisement in a 
space. Thus, a mechanism for addressing and accessing a service in a distributed 
computing environment may be published as an advertisement in a space. Clients may 
discover a space and then lookup individual advertisement for services or content. 

Figure 16 illustrates advertisement structure according to one embodiment. An 
advertisement 500, like other XML documents, may include a series of hierarchically 
arranged elements 502. Each element 502 may include its data or additional elements. 
An element may also have attributes 504. Attributes may be name-value string pairs. 
Attributes may store meta-data, which may facilitate describing the data within the 
element. 

In some embodiments, an advertisement may exist in different distinct states. One 
such state may be a drafted state. In one embodiment, advertisements may initially be 
constructed in a drafted state that exists outside the bounds of a space. The creator of an 
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advertisement may construct it in a variety of ways, including using an XML editor. 
Access to elements and attributes in the drafted state may be at the raw data and 
meta-data levels using any suitable means. Typically, events are not produced for 
changes made to advertisements in the drafted state. Therefore, the creator of the 
advertisement may be free to add, change, or delete elements as well as to achieve the 
desired attribute set, and then publish the advertisement for the rest of the distributed 
computing environment to see. 

In one embodiment, another possible state for advertisements is a published state. 
Advertisements may move to the published state when inserted into a space. Once the 
advertisement is in a space, interested clients, and services may locate it, e.g. using its 
name and/or its elements as search criteria. For example, search criteria may be specified 
as an XML template document that may be compared (e.g. by the space service) with the 
advertisements in the space. Pubhshed advertisements may represent "on-line" services 
ready for clients to use. The message address (URI) of the service may be stored as an 
element in the advertisement. Advertisements that are removed from the space may 
transition back to the drafted state where they may be discarded or held. Removal may 
generate an event so interested listeners may be made aware of the change. Message 
gates are typically created from published advertisements. 

In one embodiment, yet another possible state for advertisements is a persistent 
archived state. An archival procedure may turn a live published advertisement into a 
stream of bytes that may be persistently stored for later reconstruction. Archived 
advertisements may be sent (e.g. in their raw XML form) from the space to an archival 
service. The URI for an advertisement's archival service may be stored as an element in 
the advertisement. XML may provide a format for storing and retrieving advertisements 
and representing the state of advertisement elements sufficient to reconstruct the 
advertisement object(s). Advertisements may be stored in other formats as well, 
depending on archival service implementation. The process of making a published 
advertisement persistent may prepare the advertisement for the persistent archived state. 



Atty. Dkt. No.: 5181-66100 



72 



Conley Rose & Tayon, P.C. 



Persistent advertisements may be stored (e.g. by an archival service) for future use in a 
persistent storage location such as a file or a database. A space through the archival 
procedure may enable advertisements to be stored, however the space does not 
necessarily play a role in how persisted advertisement entries are actually stored. How 
persisted advertisements are stored may be determined by the advertisement's archival 
service. Typically, no events are generated on behalf of archived advertisements. Also, 
changes may not be allowed for advertisements in the persistent archived state. 

Figure 17 illustrates one example of advertisement state transitions that an 
advertisement may undergo during its lifetime. First, an advertisement may be 
constructed, as indicated at 1. During construction, the advertisement is in the drafted 
state. Then, the advertisement may be inserted in a space, as indicted at 2. The 
advertisement may be inserted as a published parent. The advertisement is in the 
published state after being inserted in a space. An event (e.g. AdvInsertEvent) may be 
generated when the advertisement is inserted in the space. Events are more fully 
discussed below. The advertisement may be archived and made persistent, as indicated at 
3, which may transition the advertisement to the persistent archived state. An 
advertisement may also be published from the persistent archive state, as indicated at 4. 
An advertisement may be removed from a space and transition back to the drafted state, 
as indicated at 5. An event (e.g. AdvRemoveEvent) may be generated when the 
advertisement is removed. 

In one embodiment, the archived, persistent state is not used. In this embodiment, 
state changes 3 and 4 also are not used. In this embodiment, an advertisement is either in 
the drafted state or in the published state. 

Advertisements stored in a space may have the following standardized elements 
and/or attributes: version (may be an element), creation date (may be an attribute), 
modification date (may be an attribute), implementation service URI (may be an 
element), and/or persistence archival service URI (may be an element). 
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A space itself is typically a service. A space service may provide the ability to 
search for advertisements in the space, which may include searching the space by type of 
advertisements. A space service may also provide facilities to read advertisements, write 
(publish) advertisements, and take (remove) advertisements. A space may also provide 
the ability to subscribe for space event notification messages. Some spaces may provide 
extended facilities, such as facilities to navigate space relationship graph by position; 
read, write or take advertisement elements; read, write or take advertisement attributes; 
and subscribe for advertisement event notification messages. Space facilities are 
described in more detail below. A space's capabilities are embodied in a space 
advertisement's message schema. From the message schema, space address, and 
authentication credential, a client message gate may be created to access the space and its 
facilities. 

Spaces and all advertisements within a space may be addressed using URIs. In 
one embodiment, space and advertisement names may follow URL naming conventions. 
The use of URIs, e.g. URLs, for addressing spaces may allow spaces to be addressable 
throughout the Internet, in some embodiments. 

The space message recipient (a space service) may be specified using a URI which 
may have been received in a service advertisement for the space. The URI may include a 
protocol, host, port number, and name. The protocol may name the protocol that may be 
used to move messages between clients and the space (reliable or un-reliable sockets, for 
example). The host and port number may be protocol dependent IDs. The name may be 
the space name followed by advertisement, element and/or attribute name. In one 
embodiment, a pathname may be used to identify an advertisement in a space. Pathnames 
may be either absolute or relative. Absolute pathnames name the space as well as an 
advertisement. Relative pathnames are relative a designated advertisement within an 
assumed space. In one embodiment, the syntax rules governing the construction of 
pathnames is that of the URI (Uniform Resource Identifier). In that embodiment. 
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advertisement and space names therefore may not contain any URI reserved characters or 
sequences of characters. Pathnames to elements and attributes may also be specified 
using a URL In general, element and attribute names may be appended to the pathname 
of an advertisement, such as: 

http://java.sun.com/spacename/advertisement/element/attribute. 

In one embodiment, the distributed computing environment may include a 
mechanism that allows a client to discover the URI of a space but restricts access to the 
service advertisement for the space. In one embodiment, rather than returning the full 
advertisement to the space, the URI of the space and the URI of an authentication service 
for the space may be returned. In order for the client to access the documents or services 
advertised in the space, the client first may authenticate itself to the authentication service 
at the URI provided in the return message. The authentication service may then return an 
authentication credential that may allow the client partial or full access to the space. 
When the client receives the authentication credential, the client may attempt to connect 
to the space to access the documents or service advertisements in the space. 

The distributed computing environment may provide a mechanism or mechanisms 
that may enable a client to connect to a space. Embodiments of a connection mechanism 
may provide for client-space addressing, client authorization, security, leasing, client 
capabilities determination, and client-space connection management. A client-space 
connection may be referred to as a session. In one embodiment, a session may be 
assigned a unique session identification number (session ID). The session ID may 
uniquely identify a client-space connection. In one embodiment, a session lease 
mechanism may be used to transparently garbage collect the session if the client does not 
renew the lease. 

The following is an example of using such a connection mechanism according to 
one embodiment. A client may obtain an authentication credential. In one embodiment. 
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the space may provide an authentication service in response to a client's request for 
access to the space. The client may obtain the authentication credential through the 
authentication service. When the client receives the authentication credential, the client 
may initiate a connection to the space by sending a connection request message. In one 
5 embodiment, the connection request message may include the URI address of the space 
service, the authentication credential for the client and information about the connection 
lease the client is requesting. After the space receives the connection request message, 
the space may validate the message. In one embodiment, an XML schema may be used to 
validate the message. The client may then be authenticated using the authentication 
10 credential. In one embodiment, the information received in the connection request 
message may be used to determine the capabilities of the client to use the space. In one 
^ embodiment, each client of a space may be assigned its own set of capabilities for using 

the space. In one embodiment, an access control list (ACL) that may include capability 

m 

information about one or more clients of the space may be used in client capabilities 



S 15 determination. In one embodiment, the information received in the connection request 

yi 

p message may be used to look up the client's capabilities in the ACL. 



After authenticating the client and determining the client's capabilities, the 
connection lease to grant the client may be determined. After the lease is determined, the 
20 structure for maintaining the client-space connection may be generated. A session ID for 
the connection may be generated. In one embodiment, each client-space connection may 
be assigned a unique, session ID. In one embodiment, an activation space may be created 
and assigned to, or alternatively a pre-existing activation space may be assigned to, the 
client-space session. In one embodiment, an activation space may be used to store results 
25 of services for the client when using the space. In one embodiment, a client's capabilities 
may be used to determine if an activation space is to be created for the client. For 
example, a client may not have capabilities to access an activation space to store and 
retrieve results. A message or messages may be sent to the client informing the client that 
the connection has been established. The message or messages may include the session 
30 ID and information about the lease. The client may then use the space including, but not 
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limited to: advertisement lookup, advertisement registering, and advertisement retrieval. 
In one embodiment, he connection may remain open until the allocated lease expires or 
until the client sends a message requesting lease cancellation to the space. In one 
embodiment, the client may be responsible for renewing the lease before the lease 
expires. If the lease expires before the client renews the lease, the connection may be 
dropped, causing the client to lose the connection to the space. In one embodiment, to 
reconnect, the client may be required to repeat the connection procedure. 

In one embodiment, a client of a space may obtain a space's advertisement several 
different ways. Some of the ways a client may obtain a space's advertisement are 
illustrated in Figure 18. For example, a space discovery protocol may be provided as part 
of the distributed computing environment. Space discovery is a protocol a client or 
service may use to find a space. A listener agent 202 may be configured associated with 
one or more spaces to listen for discovery requests. The discovery listener agent 202 may 
listen on various network interfaces, and may receive either broadcast requests or unicast 
requests (at the URI of the agent) from clients 200a looking for a space(s). The listener 
agent 202 then responds with the service advertisement(s) or URIs for the service 
advertisements of the requested space(s). In one embodiment, the listener agent is, in 
general, separate from the space, because its functionality is orthogonal to the 
functionality of a space service. However, the listener agent may be implemented on the 
same device or a different device as a space service. 

In one embodiment, the discovery protocol may be a service advertised in a 
default space. A client may instantiate the discovery protocol from the client's default 
space in order to discover additional spaces. The discovery protocol may be pre- 
registered with a client's default space. Alternatively, the discovery protocol may register 
itself with the default space by placing an advertisement in that space, e.g., when a client 
connects to a local network serviced by the discovery service. 
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In one embodiment, the space discovery protocol may be mapped to underlying 
device discovery protocols for other platforms, such as SLP, Jini, UPnP, etc. Thus, a 
client may use the discovery protocol of the distributed computing environment to find 
services in other environments. A bridge to these other environments may be provided 
and advertisements provided services in these other environments so that they may be 
accessed by clients of the distributed computing environment described herein. Refer to 
the Bridging section. 

For each advertised discovery protocol, the distributed computing environment 
may create a subsequent results space to hold the results of the discovery protocol. In one 
embodiment, space services in the distributed computing environment may use the 
Multicast Announcement Protocol (multicast UDP) to announce themselves on a LAN. 
This information may be recorded by a listener agent. A device (either a client or service) 
may use the Multicast Request Protocol (multicast UDP) to initiate discovery of a space 
manager. In one embodiment, the space managers respond v/ith information indicating 
the URI of their respective spaces. Alternatively, a listener agent may respond for 
multiple spaces. The discovery response may also include a short string that labels the 
each space (e.g. obtained from keywords of the space), and information that can be used 
to set up a TCP connection, for example, with each space manager to perform operations 
on the respective space. Since the requesting device may receive responses from more 
than one space manager (or multiple space listings from a listener agent), this information 
may help the client select which space it wishes to connect to. 

In addition to the multicast discovery described above, the discovery service may 
also perform discovery using unicast messaging (e.g. over TCP) that can be used to 
discover a space manager at a known address on the network (e.g. the Internet, other 
WAN, LAN, etc). The unicast discovery message may include a request for a space 
service at a known URI to provide its service advertisement. The multicast and unicast 
discovery protocols are defined at the message level, and thus may be used regardless of 
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whether the devices participating in the discovery support Java or any other particular 
language. 

The discovery protocol may facilitate the proliferation of clients independently of 
the proliferation of server content that supports those clients within the distributed 
computing environment. For example, a mobile client may have its initial default space 
built into its local platform. In addition to local services advertised in the default space, 
the mobile client may have services that search for additional spaces, such as a service to 
access the discovery protocol or a service to access space search engines. 

In some embodiments, the multicast and unicast discovery protocols may require 
an IP network. Although these discovery protocols meet the needs of devices that are IP 
network capable, there are many devices, that may not be directly supported by these 
discovery protocols. To meet the needs of such devices in discovering spaces in the 
distributed computing environment, a pre-discovery protocol may used to find an IP 
network capable agent. The pre-discovery protocol may include the device sending a 
message on a non-IP network interface requesting a network agent. The network agent 
may set up a connection between itself and the device. Once the connection between 
device and agent is set up, the agent participates in the discovery protocol on IP networks 
on behalf of the device for which it serves as agent. The network agent may also provide 
an interface for the device to the distributed computing environment in general. For 
example, gates may be constructed in the agent on behalf of the device for running 
services advertised in discovered spaces. See the Bridging section. 

Another way that clients may locate spaces in the distributed computing 
environment is by advertisement of a space in another space. A space is a service, 
thereforeso, like any other service, it can be advertised in another space. As shown in 
Figure 18, a client 200b may find an advertisement 206 in a first space 204a for a second 
space 204b. Space 204b may in turn include advertisements to additional spaces. 
Because a service (implementing a space) may also act as a client, spaces may exchange 
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advertisements or chain together to provide a federation of spaces, as illustrated in Figure 
19. Any number of spaces may be included in the distributed computing environment. 
The number and topology of spaces may be implementation dependent. For example, 
spaces implemented on an IP network might each correspond to a different subnet. 

A third way a client may locate a space is through running a service 208, as shown 
in Figure 18. A service 208 may be run which returns as its results the service 
advertisements of space services. Since service advertisements are XML documents and 
since the distributed computing environment may include the Internet, service 208 may be 
a Web-based search tool. An example of such a service is the space look-up service 
described in conjunction with Figure 4. In one embodiment, spaces within the distributed 
computing environment may be implemented as Web pages. Each Web page space may 
include a keyword that may be searched upon to identify the Web page as a space in the 
distributed computing environment. The space may include other searchable keywords as 
well to further define the space. A client may connect to a search service 208 and supply 
keywords to the search service in the form of XML messages. The search service may 
receive the keywords from the client and feed the keywords to an Internet search engine, 
which may be a conventional or third-party search engine. The search service may return 
the results from the Internet search engine to the client, either directly as XML messages 
or by reference to a results space. The results may be the URIs of spaces matching the 
search request. Alternatively, the search service may contact spaces identified by the 
search, obtain the service advertisement for each such space, and return the space service 
advertisements to the client, either directly as XML messages or by reference to a results 
space. The client may then select a space from the search results and construct a gate (by 
itself or through a proxy) to access the selected space. Once the selected space is 
accessed, the client may look up service advertisements within that space, which may 
lead to additional spaces. 

As described above, a space may be an XML-based Website, and as such may be 
searched via Internet Web search mechanisms. A space may include Internet searchable 
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keywords. Some devices, such as small client devices, may not support an internet 
browser. However, such devices may still perform Internet searches for spaces within the 
distributed computing environment. A device may have a program that accepts strings of 
keywords, which may be sent to a proxy program on a server (e.g. a search service). The 
proxy may send the strings to a browser-based search facility (e.g. an internet search 
facility) to perform the search. The proxy may receive the output of the search and parse 
it into strings (e.g. XML strings) representing each URI for the search results and send the 
response strings back to the client. Thus, a client may locate spaces through the Internet 
without having to support a program such as a Web browser. More capable devices may 
avoid the use of a proxy and initiate an Internet-based search service directly. 

A fourth way a client may locate a space is by obtaining or receiving information 
about a newly created empty space or a spawned space when an existing space is 
spawned. An existing space may include an interface for spawning an empty space with 
the same functionality (e.g. same XML schema) as the space from which it is spawned. 
Spawning of spaces is further described below. 

Once a client of a space finds the advertisement of a space service, that client of 
the space may run the space service, as it would any other service. Note that the client of 
the space service may be another service (e.g. a service seeking to advertise in the space). 
In one embodiment, as illustrated in Figure 20, to run a space service, the client of the 
space may first run an authentication service for the space to obtain an authentication 
credential, as indicated at 300. The authentication service may be specified in the service 
advertisement of the space service. The client of the space uses the authentication 
credential, the XML schema of the space (from space's service advertisement), and the 
URI of the space (from space's service advertisement) to construct a gate for the space, as 
indicated at 302. The client of the space may then run the space service by using the gate 
to send messages to the space service. A first such message is indicated at 304. 
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For embodiments employing authentication, when the space service receives the 
first message from the cHent, with the authentication credential embedded, the space 
service uses the same authentication service (specified in the service advertisement of the 
space service) to authenticate the client, thus establishing its identity, as indicated at 306. 
The space service may determine the chent's capabilities and bind them to the 
authentication credential, as indicated at 308. 

As indicated at 310, a client of a space may run various space facilities by sending 
messages to the space service. In one embodiment, when a client of a space sends a 
request to the space service, it passes its authentication credential in that request, so the 
space service can check the request against the client's specific capabilities. 

Each space is typically a service and may have an XML schema defining the core 
functionality of the space service. The XML schema may specify the client interface to 
the space service. In one embodiment, all space services may provide a base-level of 
space-related messages. The base-level space functionality may be the basic space 
functionality that is capable of being used by most clients, including small devices such 
as PDAs. It may be desirable to provide for additional functionality, e.g. for more 
advanced clients. Extensions to the base-level space may be accomplished by adding 
more messages to the XML schema that advertises the space. For example, in one 
embodiment, the base-level messages do not impose any relationship graph upon the 
advertisements. Messages, for example, to traverse a hierarchy of advertisements may be 
a space extension. Providing such additional functionality may be done by providing one 
or more extended XML space schemas or schema extensions for a space. The extended 
schemas may include the base schema so that clients of an extended space may still 
access the space as a base space. 

In one embodiment, a base space service may provide a transient repository of 
XML documents (e.g. advertisements of services, results of running services). However, 
a base space service in one embodiment may not provide for advanced facilities to 
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support persistence of space content, navigation or creation of space structure (e.g. 
hierarchy), and a transactional model. A mechanism for supporting persistence, 
hierarchy, and/or transactions is by extending the XML schema. Since extended spaces 
still include the base XML schema, clients may still treat extended spaces as base spaces, 
when just the base space functionality is all that is need or all that can be supported. 

In one embodiment, the base space may be transient. The base space may be 
acceptable for many purposes. Service providers may register their services in various 
spaces. In one embodiment, services must continuously renew leases on the publishing of 
information in the spaces. By this nature, the services advertisements may be transient in 
that they may often be rebuilt and/or reconfirmed. However, it may be desirable to 
provide for some persistence in a space. For example, a space that has results may 
provide some persistence for users that want to be sure that results are not lost for some 
time. In one embodiment, persistence may be provided for by specifying a space 
interface where the client may control which objects in the space are backed by a 
persistent store and manage the maintenance of that persistence store. The persistence 
interface may be specified with extended XML schema for the space defining the 
interfaces for persistence. 

In one embodiment, a base space may provide an interface where an XML 
document may be added to a space and identified by a string. The base space may not 
provide any hierarchy for the various so named XML documents in the space. In 
embodiments where hierarchy support is desired, additional interfaces may be defined 
(extending the XML schema) where a hierarchy can be specified by the user. Other 
interfaces may be specified to navigate the hierarchy or navigate a relationship graph by 
position. However, other users may still use the base space interfaces to access those 
same documents, without any hierarchy. Interfaces for other space structure may be 
provided for as well in extended space schemas. 
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Extended XML space interfaces may also be provided for space transaction 
models. For example, an extended space XML schema may be provided specifying an 
interface for ACID transactions. ACID is an acronym used to describe four properties of 
an enterprise-level transaction. ACID stands for Atomicity, Consistency, Isolation, and 
Durability. Atomicity means that a transaction should be done or undone completely. In 
the event of a failure, all operations and procedures should be undone, and all data should 
rollback to its previous state. Consistency means that a transaction should transform a 
system from one consistent state to another consistent state. Isolation means that each 
transaction should happen independently of other transactions occurring at the same time. 
Durability means that completed transactions should remain permanent, e.g. even during 
system failure. Other transaction models may also be specified in extended space 
schemas. 

Extended space schemas may be XML documents that specify the message 
interface (e.g. XML messages) for using extended space features, functionality or 
facilities. A space may have a base schema and multiple extended schemas. This may 
facilitate provided different levels of service to different clients depending upon the client 
authentication. 

Various space facilities may be provided. In some embodiments, a facility may be 
provided for the establishment of a session with the space. In one such embodiment, the 
rest of the space functionality is not available until this is done. In other embodiments, 
the notion of a session is not provided for, or is optional and/or implementation 
dependent. 

Another space facility may be to add or remove a service advertisement to or from 
the space. A space facility may also be provided for adding or removing an XML 
document (not an advertisement, but perhaps a result in a space). The space service may 
check for uniqueness of an item before allowing the addition of the item. For example, 
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each item added to the space may be associated with a user-specified string that identifies 
the item and that may be used to check for the uniqueness of the item. 

In one embodiment, a cHent may request a listing, tree or other representation of 
5 all services advertised in the space. The user may then scroll or maneuver through the 
advertisements and select the desired service. A space may also provide a look-up facility 
that allows a client to search for a service by providing keywords or string names. In one 
embodiment, a space facility may provide a mechanism to look up a space entry that has 
been added to the space. The look up facility may search by string to match for name, or 
10 wildcard, or even database query. The look up facility may return multiple entries from 
which the client may select one or perform a further narrowing search. In one 
embodiment, the look-up facility may provide a mechanism to locate a service 
advertisement matching a particular XML schema. The client may indicate a particular 
■J XML schema, or part of a particular XML, to be searched for within the space. Thus, a 

^ 15 service may be searched for within a space according to its interface functionality. 

yi 

m 

. Another space facility that may be provided in the distributed computing 

^ environment is a mechanism that allows services and clients to find transient documents 

y= based upon a typing model such as XML. The mechanism may be a general-purpose, 

20 typed document lookup mechanism. In one embodiment, the lookup mechanism may be 
based upon XML. The lookup mechanism may allow clients and services to find 
documents in general, including services through service advertisements. 

In one embodiment, a space lookup and response message pair may be used to 
25 allow clients and services to find XML documents stored within a network transient 
document store (space). The space may be a document space used to store a variety of 
documents. In one embodiment, the documents are XML documents or non-XML 
documents encapsulated in XML. Spaces are further described elsewhere herein. The 
lookup messages may work on any kind of XML document stored in the space, including 
30 service advertisements and device driver advertisements. In one embodiment, a client 
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(which may be another service) may use a discovery mechanism as described elsewhere 
to find one or more document spaces. Then, the chent may use space lookup messages to 
locate documents stored in the space. 

The distributed computing environment may include a mechanism that allows 
services and clients to subscribe to and receive events about the publication of XML 
documents. Events may include the publication of and removal of XML documents to 
and from a transient XML document repository such as a space. In one embodiment, an 
event may be an XML document that refers to another XML document. 

In one embodiment, a space event subscription and response message pair may be 
used to allow clients and services to subscribe for events regarding documents that are 
added to or removed from a space. In one embodiment, an event subscription may be 
leased using the leasing mechanisms described elsewhere herein. In one embodiment, a 
subscription may be cancelled when the lease is cancelled or expires. In one 
embodiment, a subscription may be renewed by renewing the lease to the subscription. 

In one embodiment, an event subscription message may include an XML schema 
that may be used as a document matching mechanism. Documents that match the schema 
may be covered by the subscription. In one embodiment, any document added to a space 
and that matches the XML schema may generate a space event message. 

A space facility may also be provided to which a client may register (or 
unregister) to obtain notification when something is added to or removed from the space. 
A space may contain transient content, reflecting services that at added and removed from 
the space. A mechanism may be provided to notify a client when a service becomes 
available or becomes unavailable, for example. A client may register with an event 
service to obtain such notification. In one embodiment, a client may register to be 
notified when a service having a name matching a specified string or a schema matching 
a specified schema (or schema portion) is added or deleted from the space. Thus, a query 
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to register with the space event notification facility may be the same as or similar to that 
of the service look up facility described above. 

A space may provide a facility for a client to instantiate a service advertised in the 
space. Service instantiation is the initialization done that allows a client to be able to run 
a service. On embodiment of service instantiation is illustrated in Figure 22. To 
instantiate a service, a client may first select one of the service advertisements published 
in the space, as indicated at 320. The client may use the various facilities, such as the 
look up facility, provided by the space to look up the various advertisements in the space. 
Then the client may request the space to instantiate the service, as indicated at 322. 

In one embodiment, service instantiation may include the following actions. After 
the client requests the space service to instantiate the selected service, as indicated at 322, 
the space service may then verify the client is allowed to instantiate the requested service, 
as indicated at 324. The space service may perform this verification by examining an 
authentication credential included in the clients message. The authentication credential is 
the credential the client received when it established a session with the space service. 
The space service may verify if the client is allowed to instantiate the requested service 
according to the client's authentication credential and capabilities indicated for that client. 
See the Authentication and Security section herein. 

Assuming the client is authorized, the space service may also obtain a lease on the 
service advertisement for the client with the lease request time specified by the client, as 
indicated at 326. Leases are further discussed below. The space service may then send a 
message to the client which includes the allocated lease and the service advertisement of 
the service, as indicated at 328. In one embodiment, the client may run an authentication 
service specified in the service advertisement and obtain an authentication credential, as 
indicated at 330. See the Authentication and Security section herein for more information 
on an authentication service. Next, as indicated at 332, the client may construct a gate for 
the service (for example, using the authentication credential and the XML schema and 



Atty. Dkt. No.: 5181-66100 



87 



Conley Rose & Tayon, P.C. 



service URI from the advertisement). Refer to the Gates section herein. The above 
described communication between the client and space service is performed using the 
XML messaging of the distributed computing environment. The client may then run the 
service using the constructed gate and XML messaging. The service rnay similarly 
construct a service gate for XML message conmiunication with the client. 

Another facility provided by a space service may be the spawning or creation of 
an empty space. This space facility may allow a client (which may be a service to another 
client) to dynamically create a new space. In one embodiment, this space facility may 
include an interface for spawning an empty space with the same functionality (same XML 
schema or extended schema) as the space from which it is spawned. This facility may be 
useful for generating (e.g. dynamically) spaces for results. For example, a client may 
spawn a space a request a service to place results or advertise results in the spawned 
space. The client may pass the spawned space URI and/or authentication credential to the 
service. Or a service may spawn a space for results and pass the spawned space URI 
and/or authentication credential to the client. In some embodiments, once a space is 
spawned, it may be discovered just like other spaces using one or more of the space 
discovery mechanisms described herein. 

By using a mechanism in which a space may be created via an interface in another 
space (e.g. a space spawning facility), new spaces may be created efficiently. For 
example, in one embodiment, storage for the spawned space may be allocated using the 
same facility used by the original space for storage. Also, a spawned space may share a 
common service facility with its original (or parent) space. For example, a new URI may 
be assigned to the new space. In one embodiment, the new URI may be a redirection to a 
common space facility shared with the original space. Thus, a newly spawned space may 
use the same or some of the same service code as that of the original space. 

Space facilities may also include security administration, for example, to update 
the various security policies of the space, and other administrative facilities. For 
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example, the number and age of advertisements may be controlled and monitored by a 
root space service. Old advertisements may be collected and disposed. See, e.g., the 
Leases section herein for when an advertisement may be considered old. The service 
implementing the space may be under the control of an administrator. The administrator 
may set policy in a service dependent manner. 

As mentioned earlier (see Figure 9 and accompanying text), spaces may provide a 
convenient mechanism for storing results from a service run by a client. Using a space 
for results may allow a small client to receive in pieces the results of running a service. 
Some services may generate a large amount of results. By using a space to store the 
results from a service, clients that do not have the resources to receive the full results at 
once may still use the service. Moreover, by using a space to store results, a service 
running on a fast busy server may be freed from interacting directly with a slow client 
when returning large results. Thus, the service may be freed sooner for use by other 
clients. 

A space may provide a convenient mechanism for accessing a result by different 
clients and/or at different times. For example, a client may not be able to use the entire 
result, but a user may want to access the rest of the result later using another client that 
can access it. For example, the result could be stock quote information, showing the 
current price of a stock (accessible by a PDA), and showing a chart of stock prices 
(accessible by a laptop later). Also, using a space in the distributed computing 
environment for results may allow a client to feed the result of one service into another 
service, without the necessity of downloading the result first. For example, in the case of 
the stock quote information above, the PDA could feed the chart into another service, 
which prints the chart, without the PDA having to download the chart itself. Thus, a 
results space may provide a mechanism for a client to pass to another client or service 
without the client having to handle or receive the results. 
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In different embodiments, the decision to use a space for results may be mandated 
by the service, mandated by the cHent, and/or requested by the cHent. A service may 
suggest the use of a space for its results, e.g., in its advertisement. In one embodiment, 
either the client or the service may spawn a new space for results or use an existing space 
for results. See the description herein regarding spawning spaces. 

In one embodiment, the use of a space for results does not necessarily mean that 
the service must put all results in that space. There may be alternatives for any result a 
service generates. For example, part or all of the result may be sent in-line in a message 
to the client. Alternatively, the result may be put in the space, and then a notification 
message may be sent to client, referencing the result (e.g. including a URI to the result or 
to an advertisement for the result). Another option may be to put the result in the space, 
with notification via an event from the space. For example, the client and the service may 
agree to call the result some particular name, and then the client may register with the 
space (using a space facility such as described above) to receive an event when a result so 
named is added to the space. See the description above on event notification. 

Thus, several different mechanisms may be employed within the distributed 
computing environment for a service to return results to a client. The actual results may 
be returned to the client by value in an XML message, or results may be returned to the 
client by reference with the actual results (or advertisement for the actual results) put in a 
space and the client receiving a message referencing the results in the space. Moreover, 
results, or results advertisements, may be placed in a space and the client notified by 
event. 

Another mechanism for handling results may be for the client to specify another 
service for the results to be fed to. For example, when a client runs a service that will 
produce results, the client may instruct that service (e.g. through XML messaging) to send 
the results to another service for further processing. This may involve the client 
indicating the URI of an advertisement for the other service so that the result-producing 
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service may generate a gate to the other service in order to run the other service and pass 
it the results. In this example, the result-producing service may be a client of the other 
service. In some embodiments, the client may send the schema or a pre-constructed gate 
to the result-producing service to access the service for further processing. An example 
of a service for further processing is a display service that may display the results for the 
original client. This display service may be on or associated with the same device as the 
client. 

Result spaces and method gates may allow the distributed computing environment 
to provide a simple remote method invocation that is practical for thin clients with 
minimal memory footprints and minimal bandwidth, because it need not have the adverse 
side effects of huge program objects (along with needed classes) being returned 
(necessarily) across the network to the client as in conventional remote method 
invocation techniques. Instead, results may be returned to a result space, and only if 
desired (and if they can reside on the client) are the actual objects downloaded to the 
client. 

The mechanism by which the distributed computing environment may provide for 
remote method invocation is as follows (refer also to the description of method gates in 
the Gates section herein). An object may be advertised (e.g. as a service or as part of a 
service) in a space. The advertisement includes a reference that contains the URI (e.g. 
URL) of the object, along with other access parameters, such as security credentials and 
XML schema. A client may have or may construct a client method gate for the object, 
which for every method of the object (or service) itself may have a wrapper method that 
takes the method parameters and creates a request XML message to invoke a method of 
the object. The XML message is sent to a service gate that invokes the actual method on 
the service object. When that method returns a result object, the service gate may post 
the result object in a results space, and may return a message to the client with a reference 
to the result object. 
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Thus, for a client to invoke a remote method, the client first sends a message to 
instantiate an object (e.g. service), such as described above. In one embodiment, 
instantiation of an object may include the creation or spawning of a results space. In 
another embodiment, results space creation may be independent from the object 
instantiation. Instantiation may return the object URI to the client, and the client and 
service gates may be dynamically created when a client requests instantiation. In some 
embodiments, a results space may already exist and be advertised by the object (service). 
Some part or all of the gates may also have been pre-constructed or reused. 

Once a client has initiated an object, a local call of the appropriate client method 
gate will affect a remote call to the actual remote object, as described above. The remote 
method invocation approach of the distributed computing environment may be recursive, 
with object references returned to the client, instead of the objects itself, when the client 
gate is called. Note that such returned objects may already be instantiated. In some 
embodiments, the client may make a decision to download an entire object itself, rather 
than just remotely invoke it. 

A method or service invoked as described above may generate a child gate that is 
associated with the results document. The method may return a child gate (or the schema, 
URI and credentials for the client to construct a child gate) for the references instead of 
the references themselves. The client may then access the references through the child 
gate. The child gate may also be a method gate. 

As described above, this remote method invocation provided by the distributed 
computing environment allows the real result object(s) to be stored in a service results 



space (which also may be created dynamically, by a servlet for example). The results 
space may be temporary. The results space may act as a query results cache. The results 
cache may be patrolled by server software (garbage collector) that cleans-up old result 
areas. Distributed garbage collection may be employed, as result spaces may fill up until 
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they are destroyed by a client indicating it no longer needs the space, or by an 
administrator on a server setting appropriate limits. 

Turning now to Figure 23, an illustration of a default space 350 is provided. The 
distributed computing environment may provide at least one default space so clients can 
find an initial set of advertisements. A device may have a default space that exists 
locally, with a built-in pre-constructed gate. The services advertised in that default space 
may exist locally on that device, and they may provide system software that enables or 
facilitates the device's participation in the distributed computing environment. 

The default space 350 may include one or more mechanisms 352 to locate 
external spaces, as shown in Figure 23. One service in the default space may run the 
space discovery protocol described above to find external spaces. Also, external spaces 
may be advertised in the default space. Additionally, a service (e.g. a search engine or a 
proxy service to a search engine) may be advertised in the default space that determines 
or finds external spaces. Each space may be analogous to a file system mount point. 
Thus, the distributed computing environment may provide searchable, dynamic mount 
points to services. A default space may be a client's initial mount point to the distributed 
computing environment. 

A default space or access to a default space may be built in to a device. Through 
the default space and local services that may exist on the device, a client execution 
environment for the distributed computing environment may be provided. A device's 
local services and default space service may have built-in pre-constructed gates. One of 
the built-in services listed in the default space may be a service to run the discovery 
protocol so that the client may locate additional (e.g. external) spaces. A default space 
may include a built-in service that provides an execution environment for clients that 
allows the client user to browse spaces, select, and then instantiate services. Such a 
service may provide a simple user interface that allows a client to entire strings (e.g. 
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keyword for space searches), view or browse result references (e.g. space listings, or 
service listings within a space), select items (e.g. to chose and instantiate a service), etc. 

Devices that primarily provide a service may also include a default space and may 
include a built-in service in the default space that allows a service to manage advertising 
itself in various spaces. For example, a device, such as a printer, may have a built-in 
default service that finds (perhaps through the discovery protocol) a space on a local area 
network and adds an advertisement for the printer service to that space. This service may 
also maintain the printer service advertisement within the LAN space, for example, by 
renewing its lease or updating the printer's XML schema, etc. 

For some devices that provide a service, the overhead of finding a space to 
advertise its service and maintain that advertisement is undesirable. In one embodiment, 
rather than searching for and maintaining a space or spaces to publish service 
advertisements, services on some devices may transmit their advertisements in response 
to connection requests. For example, a printer device with a printer service that is 
available on a proximity basis may not maintain an advertisement in a space (on the 
device or external to the device). Instead, when another device establishes a connection 
with the printer device (for example, a user with a laptop running a client desires to print 
a document), the printer service may transmit the service advertisement to provide the 
XML service schema for connecting to and running the service that provides printing 
functionality on the printer device. Also, some devices may only maintain advertisements 
for their services in a certain vicinity or local network. Such a device may not desire to 
support or may not have access to transports for broader accessibility. 

One example of a service device in which it may be desirable for the device to 
avoid or limit maintaining service advertisements in a space is a device whose 
functionality is available on a proximity basis. Proximity-based services may provide 
advertisements of their functionality upon request. These advertisements may not be 
broadly accessible. For example, proximity-based services may be provided in a wireless 
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communications system. The term "wireless" may refer to a communications, 
monitoring, or control system in which electromagnetic or acoustic waves carry a signal 
through atmospheric space rather than along a wire. In most wireless systems, radio- 
frequency (RF) or infrared (IR) waves are used. Typically, in proximity-based wireless 
systems, a device comprising a transceiver must be within range (proximity) of another 
device to establish and maintain a communications channel. A device may be a hub to 
connect other devices to a wireless Local Area Network (LAN). 

As mentioned, embodiments of the distributed computing environment may 
provide a mechanism using a lookup space that allows clients to rendezvous with 
services. In a proximity computing environment, one embodiment of the distributed 
computing environment may provide a service discovery mechanism that clients may use 
to discover services without using lookup spaces as rendezvous points. An example of a 
proximity computing environment is an IrDA point-to-point communications 
environment. In a proximity computing environment, the proximity mechanism may find 
the "physical" location of the service for the client. For example, in an IrDA 
environment, the client device may be physically pointed at the device including the 
service(s) that the client desires to use. 

The proximity service discovery mechanism may enable the client to directly look 
for service advertisements rather than sending a lookup request to a lookup space to look 
for service advertisements. . Since the client device may have established a proximity 
connection to the service device, the client may directly request the desired service. For 
example, a PDA client device may establish a proximity connection to a printer device; 
the client may "know" to request a printer service connection on the printer device. 

In one embodiment, the client may send a proximity service discovery message to 
the service device. The message may include information that may specify a desired 
service on the service device to which the client device has a proximity connection. In 
one embodiment, a service on the service device may respond to the proximity service 
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discovery message, and may send to the client the service advertisement that the client 
may use to connect to the desired service. The proximity service discovery message may 
also include information that may be used to authenticate the client and to estabHsh the 
client's capabilities on the service. Using the received service advertisement, the client 
5 may establish a gate to establish conmiunication with the desired service. 



Nevertheless, it may still be desirable to publish advertisements for services that 
do not desire to or cannot maintain their advertisements in a space that is broadly 
accessible. In one embodiment of a distributed computing environment, a device that 
10 establishes a connection w^ith a device that does not publish its service advertisement(s), 
such as a proximity-based device, may publish service advertisements received from the 
non-publishing device. For example, a device that establishes a connection with a 

O 

S proximity-based device and that has an alternate transport connection(s) may publish (or 

01 

republish) service advertisements received from the proximity-based device in the 
15 alternate transport environment, thus allowing the proximity-based device service(s) to be 
used by other devices (through the (re)published service advertisements) which are 
outside the normal proximity range of the device. 



yi 

111 



The publishing device may locate a locally published service advertisement for 
20 the proximity-based device through a discovery and/or lookup service, or alternatively the 
service advertisement may not be published by the local service device, but instead may 
be sent to the publishing device by the local device upon the establishment of a 
connection, as described above. In one embodiment, the republished service 
advertisement may be made available as long as the device maintaining the advertisement 
25 is connected to or able to connect to the local device. For example, if the publishing 
device is disconnected from the local device (for example, moves out of proximity range 
of the device), the service advertisement may be made stale or removed. A lease 
mechanism may be provided to allow the space containing the advertisement to send 
lease renewal messages to the publishing device. The publishing device may verify its 
30 connection to the local device, thus allowing the space to detect when the local device is 
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no longer available. Rules for how the service advertisements are republished may be 
provided by the local device or by an administrative policy for the local vicinity (e.g. 
proximity area) or local network. 

Figure 24 illustrates an example of a device bridging proximity-based devices 
onto another transport mechanism to allow the services provided by the proximity-based 
devices to be accessed by devices outside the proximity range of the devices, according to 
one embodiment. A publishing device 1404 may be connected to a network 1412, such 
as an Ethernet LAN or the Internet, etc., and may establish and maintain proximity 
connections 1414 with proximity devices 1400 and 1404. Proximity connections may be 
wireless connections or wired LAN connections, for example. Proximity devices 1400 
and 1402 may each send a service advertisement to the publishing device 1404 upon 
connection, or, alternatively, the publishing device may locate the service advertisements 
using a discovery and/or lookup service for the proximity connections. The publishing 
device 1404 may then make the services provided by the proximity devices available to 
other devices 1408 and 1410 on the network 1412 by republishing the service 
advertisements 1416 and 1418 in space 1406. Space 1406 may be stored on the 
publishing device or on other devices connected to the LAN (including devices 1408 and 
1410). 

Other devices on the LAN including devices 1408 and 1410 may then discover 
space 1406 and look up the republished service advertisements 1416 and 1418 for the 
proximity-based devices, establish gates to communicate to those services (device 1404 
may act as a proxy or bridge) on the proximity-based devices 1400 and 1402 using the 
XML message passing methods described previously, and send requests and receive 
results to the proximity devices. Publishing device 1404 may act as a bridge between the 
network 1412 and the proximity connections 1414 to the proximity-based devices. 

Leases 
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Leases may be used in the distributed computing environment to deal with partial 
failure, resource synchronization (scheduling), and to provide an orderly resource 
clean-up process. Leases may help the overall distributed system manage independent 
clients and services that may come and go. The various resources that clients obtain from 

5 services (including space services) may be leased from those services. In general, not 
every resource can or needs to be leased. In one embodiment, it is up to the 
implementation of each particular service to determine which of its resources need to be 
leased. In particular, resources used by a large amount of clients simultaneously may not 
need leasing or instead may require custom leasing protocols. This class of leasing may 

10 be left to the service provider. Custom protocols, such as those to implement transactions 
for example, may be built upon the base leasing scheme. In one embodiment, the base 
leasing model is a relative time-based model. 

Services may issue leases to clients and provide operations on those leases. In one 



zf 15 embodiment, all such lease functionality of a service is part of that service's XML 

schema. Thus, a client may use its gate (corresponding to the service and constructed for 



the service's XML schema) to perform lease operations. In one embodiment, all services 

l! that issue leases provide the following lease operations (only allowed by the owner of the 

Q 

M= lease): (i) renewing a lease (parameters specified: lease (e.g. lease ID, lease credential), 

f% 20 new lease time requested), and (ii) canceling a lease (parameter specified: lease (e.g. lease 

^ ID, lease credential)). In one embodiment, all leases are granted for a particular amount 

of relative time (duration of lease) that may be negotiated. The requestor may specify a 
certain amount of time (e.g. in seconds), and the grantor may grant the lease for any 
amount up to that time. In one embodiment, a -1 value may be used to specify an 
25 indefinite lease. 



The leasing mechanism may provide a mechanism to detect service and client 
failure. Leases may also provide a mechanism to provide shared and exclusive resource 
access. In one embodiment, all service resources either have no lease (resource is not 
30 leased and therefore available), a shared lease (resource accessed by multiple clients), or 
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an exclusive lease (resource is accessed by exactly one client at a time). In one 
embodiment, all resources begin in the no lease state. A no lease state signifies there is 
no current access to the underlying resource, and indicates that there is an interest in the 
resource remaining in existence and thus available for leasing. The leasing level may be 
increased from none to shared, none to exclusive, or shared to exclusive. Lease isolation 
levels may also be decreased from exclusive to shared, exclusive to none, and shared to 
none. In one embodiment, clients may voluntarily increase or decrease the lease isolation 
level, or may be requested by the service to do so. A response message from the service 
may indicate if the isolation level change was accepted. 

Request-response message pairs may be employed to claim, release, and renew a 
lease. Each message may be tagged using a reserved XML tag to indicate that the 
message is a leasing message. The complete composition of the message isn't necessarily 
defined by the distributed computing environment. In such an embodiment, service 
developers may append custom message content, as long as, the message is tagged as a 
leasing message. 

In one embodiment, clients that use leased resources may be expected to: (i) claim 
the resource as shared or exclusive, (ii) release the resource claim (if requested or if 
finished with resource), and (iii) respond to renewal messages (with another claim at 
same or different isolation level). Renewal messages may be sent (e.g. in regular 
intervals) by services to detect client failure cases. The interval (at which the renewal 
message is sent) may be service specific. If a response to the renewal message isn't issued 
after a specific amount of time (e.g. based on a time noted in the service advertisement), a 
resource reclamation process may begin within the service, revoking the lease completely. 
In such an embodiment, renewal messages sent to clients should be handled in a timely 
fashion. Figure 25 illustrates the use of renewal messages both between a client and an 
instantiated service and between a service provider and a space service. Note that both 
cases may be considered as the use of renewal messages between a client and a service, 
since a service provider may be a client to a space's advertisement service. 
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Renewal messages may arrive in an "out of band" fashion that may be 
inconvenient for the client to handle. That is, the client cannot predict when a renewal 
message will be sent from the service. Out of band message handling may complicate the 
5 client's logic and increate its complexity. To solve this problem, an automatic lease 
renewal mechanism may be implemented to relieve the client of the responsibility of 
handling the out of band messages, and thus reduce client complexity. In the automatic 
lease renewal mechanism, each gate (message, method, and/or event gate) may receive 
renewal messages and automatically respond to them without help from the client. The 

10 default response to a renewal request is to claim the lease at its current level. Each 
message gate may contain a single, set-aside renewal response message that is 
automatically sent to the advertisement space service when the gate receives the renewal 
message. This "out of band" message is handled on behalf of the client, yielding a 
cleaner client programming model. In one embodiment, the gate may allow clients to 

15 register lease event handlers to specify different isolation levels in the response message. 

Standard leasing messages may be defined in the distributed computing 
environment. In one embodiment, additional leasing messages may be defined by custom 
leasing models. In one embodiment, every service that issues leases may specify a URI 
20 where renew and cancel leasing messages may be sent. 

Leasing messages may include embedded credentials for authenticating the sender 
of the message. In one embodiment, a client may receive the credential (e.g. 
authentication credential) from an authentication service at service instantiation and 

25 embed the credential in messages sent to the service. In one embodiment, the 
authentication service may have been specified in the service advertisement for the 
service. The service may then authenticate the credential when received in a message 
from the client. In one embodiment, the service may send the credential when first 
received to the same authentication service used by the client to generate the credential. 

30 Thus, the issuing and embedding of credentials in leasing messages may be used to 
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provide a secure leasing environment. For example, the embedding of a credential in a 
cancel lease message may effectively prohibit anyone but the authorized, credentialed 
client (and the service issuing the lease) from canceling the lease. See the 
"Authentication and Security" section for more detail. 

Figure 44 is a flow diagram illustrating a mechanism for leasing resources. In 
step 2000, a client may request a lease on a resource provided by a service. In one 
embodiment, leases may be time-based, i.e. granted for a period to the client. In another 
embodiment, leases may be non-time-based leases that are maintained until cancelled by 
the client or the service. In one embodiment, the service may be a space service, and the 
resource may be a service advertisement for another service and leased to the client by the 
space service. In one embodiment, the service may be a space service, the client may 
itself be a service, and the resource may be the publishing of a service advertisement by 
the space service on behalf of the client/service. In one embodiment, the client may send 
a request message to the service that specified the resource and requests the lease on the 
resource. In one embodiment, the message may specify a requested lease period. In one 
embodiment, a client message gate may send the lease request message to the service on 
behalf of the client. In one embodiment, the lease request message may be an XML 
message. 

In step 2002, the service may grant the lease on the resource to the client. In one 
embodiment, the service may receive a lease request message from the client. The 
service may then grant the lease on the resource. In one embodiment, the lease request 
message may include a requested lease period. In one embodiment, the service may grant 
the lease for a granted lease period less than or equal to the requested lease period. In one 
embodiment, the requested lease period may be for an indefinite lease (i.e. the period 
does not expire). In this embodiment, the lease must be cancelled by the client or service, 
as the lease itself does not expire. 
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The service advertisement provided to the chent may be used in estabUshing an 
initial lease of resource(s) provided by the service and requested by the client during 
access of the service. In one embodiment, the lease on the resource may be granted at 
service instantiation time. In this embodiment, the client may not send a lease request 

5 message to the service requesting the lease. In this embodiment, the service may grant an 
initial lease on the resource or resources to the client when instantiated from the service 
advertisement. For example, a space service may, in response to a request message from 
a client, instantiate a service from a service advertisement on the space service. The 
service may grant the client leases on one or more resources provided by the service when 

10 instantiated without requiring the client to explicitly send a message requesting the leases. 



In step 2004, the client may request renewal of the lease. In one embodiment, the 

□ 

kg- service may send a lease renewal request message to the client. In one embodiment, the 

lease renewal request message may be sent to the client prior to expiration of a previously 
W 15 granted lease period. The client may respond to the message with a lease renewal 

0 response message to the service requesting renewal of the lease. In one embodiment 

1 using time-based leasing, the lease renewal response message may include a requested 

^ lease period. In another embodiment using non-time -based leasing, the lease renewal 

D 

M= response message may request that the lease be continued. In one embodiment, the client 

Q 20 may return a lease renewal response message that instructs the service that the lease is no 

^ longer required. In one embodiment, the client may not send a lease renewal response 

message, and the service might assume, when no response message is received by the 
service, that the client no longer requires the lease. For example, the client may have 
been disconnected from the network. This provides the service with a mechanism for 
25 detecting non-used leases and for garbage collecting resources including leasing 
resources. 



In one embodiment, the service may not send a lease renewal request message to 
the client. In this embodiment, the client may instead monitor a granted lease period and 
30 send a lease renewal message to the service prior to the granted lease period expiring. 
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The lease renewal message may specify the resource that is being leased and a requested 
new lease period for the lease of the resource. In one embodiment, the requested lease 
period may be for an indefinite lease (i.e. the period does not expire). If the client no 
longer desires the lease, the client may not send the renewal message, and thus may 
abandon the lease. 

In one embodiment, a client message gate may handle lease renewal on behalf of 
the client process, thus freeing the client process from responsibility of handling lease 
maintenance. In one embodiment, the client message gate may automatically respond to 
lease renewal request messages send from the service. In one embodiment, a default 
lease renewal response message may be compiled into the gate and automatically sent to 
the service upon the gate receiving the lease renewal request message. In another 
embodiment, the service may not send lease renewal request messages. In this 
embodiment, the client gate may automatically send lease renewal messages. In one 
embodiment, the automatic sending may be performed periodically. In one embodiment, 
the client message gate may monitor a currently granted lease period and may send a lease 
renewal message prior to the currently granted lease period expiring. 

In one embodiment, a lease may be at one of several access levels including 
exclusive access and shared access. Exclusive access gives the client exclusive rights to 
the resource, prohibiting other clients from accessing the resource for the duration of the 
lease. Shared access gives other clients the right to contemporarily lease the same 
resource as the client, that is, to obtain a lease to the resource that overlaps the period of 
the lease held by the client. In one embodiment, the client may hold a lease at one access 
level, and may send a lease renewal message requesting the lease at another access level. 

In step 2006, the service, subsequent to receiving a lease renewal message from 
the client, the service may grant renewal of the lease of the resource to the client. The 
lease renewal message may have been sent in response to a lease renewal request message 
sent from the service to the client or may have been sent automatically by the client prior 
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to a previously granted lease period expiring. In one embodiment, the lease may be 
granted for a granted lease period. In one embodiment, the lease renewal message may 
have requested a lease renewal period. In one embodiment, the granted lease period may 
be less than or equal to the requested lease period. In one embodiment, the service may 

5 deny the lease renewal request by the client. For example, the client may have exceeded a 
maximum cumulative lease time, or another client may require exclusive lease access to 
the resource. In one embodiment, the service may grant the lease for less than the 
requested lease period. In one embodiment, the service may send a message to the client 
to inform the client if the lease has been renewed. In one embodiment, the message may 

10 include the granted lease period. 



u 



In step 2008, the client may send a message to the service requesting cancellation 
of the lease. The message may specify the resource for which the client has a lease to be 
cancelled. In step 2010, the service may cancel the lease. The service may cancel the 

15 lease in response to receiving a cancel lease request message as described in step 2008. 
In one embodiment, the service may also cancel the lease if a granted lease period expires 
without receiving a lease renewal message from the cHent. The service may also cancel 
the lease for a variety of other reasons. For example, another client may request exclusive 
access to the resource, or the resource may become unavailable. In one embodiment, the 

20 service may send a message to the client to inform the client if the lease has been 
cancelled. 



In one embodiment, a security credential, such as an authentication credential 
described below, may be included in lease messages sent between the client and service 

25 as described in Figure 44. For example, the client may embed the security credential in 
lease renewal and lease cancel request messages sent to the service. The service, upon 
receiving a message, may examine the credential to verify it is from the leaseholder, and 
thus to verify the authenticity of the message. This provides security in the leasing 
mechanism by preventing entities not having the proper credentials from modifying the 

30 client's current lease(s) with the service. 
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In one embodiment, the lease messages sent between the client and the service 
may all be in a data representation language. In one embodiment, the data representation 
language may be extensible Markup Language (XML). In one embodiment, all messages 
may be sent and received by a service message gate and a client message gate. In one 
embodiment, the lease messages may be described in an XML message schema provided 
to the client and used to construct the client message gate. In one embodiment, the XML 
message schema may have been acquired by the client in a service advertisement, for 
example, retrieved from a space service. 

A space service may use leases to manage the resources its facilities provide to 
clients (including other services) of the space. For example, when a client desires to use a 
service, the space service may request a lease for the client as part of service instantiation. 
Service instantiation may be performed to allow a client to run a service. To instantiate a 
service, a client may first select one of the service advertisements published in a space. 
The client may use the various facilities provided by the space to look up advertisements 
in the space. Then the client may request the space to instantiate the service. The lease 
acquired during service instantiation is on use of the service advertisement (not the same 
as the lease on publishing of the service advertisement). It should be noted that the space 
service may allow multiple clients to have a lease on use of a service advertisement if the 
advertisement has an indication it is shared. Otherwise, the space service only allows one 
client at a time to have a lease on the service advertisement (exclusive). 

Another example of how a space service may uses leases to manage the resources 
its facilities provide to clients is when a client of the space registers to be notified when 
XML documents (e.g. service advertisements) are added or removed from a space. The 
registering client of the space may obtain a lease on this subscription to notifications. 
This lease enables the space service to know whether to continue sending notifications. 
Such a lease may not be necessary when a client has established an active session with the 
space. Also, note that when a client of a space (could be a service) establishes a session 
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with the space, the client may obtain a lease on the session. This allows the space to 
manage any resources associate with the session. 

In another embodiment, the distributed computing environment may employ a 
leasing mechanism that is not time-based. The lease may be generated when an object is 
claimed for use. Instead of a time-based mechanism, the claim method may accept a 
callback that notifies the current leaseholder that some other party wishes access the same 
object (e.g. service). Thus, as an alternative embodiment to time-based leases, instead 
clients may make claims on space objects (e.g. services).When another client desires a 
lease that is incompatible with the current leaseholder's, the service may send a "callback 
message" to the client. Upon receiving the callback message, the client (i.e. client gate) 
may invoke a callback method to decide on a response to the callback message (keep the 
lease, cancel the lease, change the access level to shared, etc.). Once a response has been 
determined, the client gate sends a response message to the service. This distributed 
mechanism for managing leases may be implemented using the XML message-passing 
layer. 

Authentication and Security 

The distributed computing environment provides for spontaneous and 
heterogeneous distributed systems based upon an asynchronous message passing model, 
where data and/or objects may be represented in a representation language such as XML. 
In the distributed computing environment, clients may connect to services throughout the 
Internet, for example. The distributed computing environment may enable large numbers 
of network devices to work together in a reliable, dynamic, and secure fashion. The 
distributed computing environment may define a protocol that substantially enables 
interoperability between compliant software components (clients and services). 

In the context of the distributed computing environment, a device may be a 
networking transport addressable unit. Clients and services may be implemented as 
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Universal Resource Identifier (URI) addressable instances of software or firmware that 
run on devices. 

Internet space is inhabited by many points of content. A URI is a method used to 
identify any of those points of content, whether it be a page of text, a video or sound clip, 
an image, software, firmware or other Internet content. The most common form of URI is 
the Web page address, which is a particular form or subset of URI called a Uniform 
Resource Locator (URL). A URI typically describes the mechanism used to access the 
resource, the specific computer that the resource is housed in and the specific name of the 
resource (typically a file name) on the computer. 

Clients and services (both may be implemented on devices as software and/or 
firmware) may be connected over the Internet, a corporate intranet, a dynamic proximity 
network, within a single computer, or by other network connection models. The size and 
complexity of the devices supporting clients and services may range, for example, from a 
simple light switch to a complex, highly available server. Example devices include, but 
are not limited to: PDAs; cellular phones; notebook, laptop, and more powerful PCs; and 
more powerful computer systems, up to and including supercomputers. In some 
embodiments, the distance, latency, and implementation of clients and services may be 
abstracted, with a common discovery and communication methodology, creating a "black 
box" effect. This definition approach allows software implementation issues to be dealt 
with by the underlying platform, yielding a loosely coupled system that may be scaled to 
Internet proportions. 

The distributed computing environment may provide an Internet-centric 
programming model including WEB and XML content representation, dynamic device 
discovery, and secure device communication that is accessible from a wide range of 
network devices. The distributed computing environment may include a network 
programming model abstracted above the CPU level. The programming model may 
include the following properties: 
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• URI addresses 

• Strongly typed data called content (addressed with URIs) 

• Substantially unlimited amount of persistent content storage (e.g. stores), 
(containing XML and non-XML content, such as that identified by MIME types) 

• Substantially unlimited amount of transient content memory called spaces 
(containing XML content) 

• Descriptive XML metadata (data about data) content advertisements that may be 
stored in a space to notify interested clients. 

• A substantially unlimited number of instructions (embodied as messages) 

• Secure message endpoints (gates) addressed by URIs 

• Data flow support (event messages) to coordinate work flow between distributed 
software programs 

Services and clients may run as programs within the distributed computing 
environment. Services may advertise their capabilities to clients wishing to use the 
service. Clients may or may not reside within the same network device, and that device's 
code execution environment may or may not support the Java platform. 

Using URIs to address content and message endpoints gives the distributed 
computing environment a powerful addressing scheme. The address may specify the 
location of the content or endpoint, and may specify the route (or transport protocol) to be 
used. Items addressed using URIs also may have an associated security credential. The 
security credential may be used to control what clients are allowed access to the item, as 
well as which operations authorized clients are allowed to perform on that item. 

The high degree of access provided by the distributed computing environment 
may be controlled by appropriate authentication and security systems and methods. 
Authentication and security in the distributed computing environment may include, but 
are not limited to: verifying the typing correctness of XML content in a message; securely 
identifying the sender to the receiver; a mechanism to check the integrity of messages 
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sent from a client to a service and vice versa; and a mechanism of describing a service's 
set of accepted messages to a client and enforcing the message requirements on messages 
received at the service. The above listed security and authorization features may be 
leveraged in a single, atomic unit of code and data. The atomic unit of code and data may 
be dynamically created. In one embodiment, once created, the atomic unit of code and 
data may represent a message endpoint (gate), and may not be altered as to the security 
and authorization policies implemented during creation. 

A gate may represent the authority to use some or all of a service's capabilities. 
Each capability may be expressed in terms of a message that may be sent to a service. 
Gates may also be used for failure case detection when a client leases resources. 

Authentication and security may also include a mechanism for verifying that a 
client attempting to use a service is authorized to use the service; that the space from 
which the client receives the service advertisement from is authorized to provide the 
service advertisement; and/or that the service advertisement itself is authorized. 

Message passing may be implemented in a messaging layer as the means of 
communicating requests from clients to services and of the services responding with 
results to the clients. The messaging layer of the distributed computing environment may 
substantially guarantee that valid XML messages are sent, and may provide mechanisms 
enabling a language-independent security model. In the messaging layer, a sending 
message endpoint may be linked to a receiving message endpoint. The two associated 
message endpoints may provide a secure, atomic, bi-directional message channel suitable 
for request-response message passing between a client and a service. 

In embodiments of a distributed computing environment, an advertisement may be 
published in a space for a service. An advertisement may be an XML document that 
includes the XML schema and URI of the service. The service may also include a 
service ID token or credential in the advertisement, and may specify in the advertisement 
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an authentication service to be used by both the client and the service. A client may then 
locate the service advertisement on the space, and use the advertisement to instantiate a 
message gate on the client. The client may use the authentication service specified in the 
advertisement to obtain an authentication credential for sending in messages to the client. 

5 In one embodiment, the client may pass the service ID token or credential from the 
service advertisement to the authentication service, and the authentication service may 
then use the service token or credential to generate the authentication credential for the 
client. In one embodiment, the client may include a gate factory that receives the 
necessary information to create the message gate, and the gate factory may construct the 

10 message gate and communicate with the authentication service to obtain the 
authentication credential for the client. A corresponding service message gate may be 
instantiated at the service. 

The client, at some point, sends a first message to the service. In one 
15 embodiment, the client message gate may embed the client's authentication credential 



^ constructed by the authentication service in the message. When the service receives the 

Li 

\ message, it may use the same authentication service to verify the authentication credential 

^ received in the message. By sharing the same authentication service, any of a variety of 
authentication protocols may be employed, with the details of generating the 

g 20 authentication credentials separated from the client and the service. Thus, a client may 

^ use different authentication credential protocols with different services. 



In one embodiment, the authentication service may determine the capabilities of 
the client (e.g. what the client is allowed to do on the service) upon first receiving the 

25 client authentication credential from the service. The capabilities of the client may be 
bound to the client's identity. Then, the client's message gate may embed the 
authentication credential in every message sent from the client to the service. The 
messages may be received by the service message gate and then checked by the 
authentication service to ensure that the message is from the client and that the message 

30 request is within the capabilities of the client. In another embodiment, capability 
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determination and message checking for capabilities may be handled by the service 
message gate without using the authentication service. 

The client and service message gates may work together to provide a secure and 
reliable message channel. The gates may serve as secure message endpoints that allow 
the client to run the service by sending and receiving secured, authorized XML messages 
to and from the service. 

Operations in the distributed computing environment may be embodied as XML 
messages sent between clients and services. The protocol used to connect clients with 
services, and to address content in spaces and stores, may be defined by the messages that 
can be sent between the clients and services. The use of messages to define a protocol 
may enable many different kinds of devices to participate in the protocol. Each device 
may be free to implement the protocol in a manner best suited to its abilities and role. 

A service's capabilities may be expressed in terms of the messages the service 
accepts. A service's message set may be defined using an XML schema. An XML 
message schema may define each message format using XML typed tags. The tag usage 
rules may also be defined in the schema. The message schema may be a component of an 
XML advertisement along with the service's message endpoint (gate) used to receive 
messages. Extensions (more capabilities) may be added to services by adding messages 
to the XML message schema. 

In the distributed computing environment, authorized clients may be able to use 
all of a service's capabilities, or may be limited to using a subset of the service's 
capabilities. In one embodiment, once a set of capabilities has been given to a client, the 
client may not change that set without proper authorization. This model of capability 
definition may allow for services levels that run from a base set of capabilities to an 
extended set. 
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Service instantiation may be performed to allow a client to run a service. To 
instantiate a service, a client may first select one of the service advertisements published 
in a space. The client may use the various facilities provided by the space to look up 
advertisements in the space. Then the client may request the space to instantiate the 
service. Service instantiation may include, but is not limited to, the following steps: 

1. Client requests space service to instantiate a service. 

2. Space service verifies client is allowed to instantiate the service. 

3. Space service obtains a lease on the service advertisement for the 
client with the lease request time specified by the client. Alternatively, 
the service advertisement may be provided to the client without using 
the leasing mechanism. 

4. Space service sends a message to the client that includes the lease 
allocated in steps 3, and the service advertisement of the service. 

5. Client runs the authentication service specified in the service 
advertisement, and obtains an authentication credential. 

6. Client constructs a client message gate for communicating with the 
service. 

In order to provide trust between clients and services in the distributed computing 
environment, a series of dynamically generated numbers (keys, or tokens) may be used as 
security or authentication credentials for clients. One or more credentials may be used to 
verify the right of a client to use a service and to verify messages between the client and 
the service. Each client and service may have a unique credential. 

The type of authentication credential needed to use a service may be returned to 
the client conducting a service search. In one embodiment, an authentication credential is 
an opaque object that must be presented each time a client uses a service. In one 
embodiment, the authentication credential may be presented by a message gate on behalf 
of a client in every message sent to a service. No matter what kind of authentication 
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credential is required by a service, by using an authentication service external to the client 
and the service, the client and the service may not need to be aware of the authentication 
credential structure or of the authentication process. 

An authentication credential may also include a transport-specific ticket in 
addition to the service ticket. When running a service, depending upon the networking 
transport specified in the service advertisement, the transport may provide a secure 
connection. In some cases, if the data link layer is already secure, it may not be necessary 
to use a secure transport over the already secure data link layer. 

The concept of an authentication credential is abstract enough to allow various 
levels of security based upon credential implementation. Levels of security may include, 
but are not limited to: 

1. None (no message security - credential is empty or no credential) 
Messages with empty credentials or no credentials may be sufficient 
when security is enforced by the physical connectivity properties of the 
transport. For instance, a smart light switch connected to just one light 
switch controller is secure because the switches are wired in a secure 
manner. 

2. Signed messages (digital signatures) 

Signed messages may include a digital signature that enables the 
service (receiving the message) to verify the origin (client) of the 
message. 

3. Encrypted messages (transport may handle this) 

Encrypted messages add another level of security by scrambling the 
message contents so that another credential is required to unscramble 
it. 

4. Capability messages (service functionality and user aware) 
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This level of security may provide for security capabilities on a user- 
by-user basis (e.g. what the user is allowed to do), and may allow for 
fine-grained access control to services and individual service 
functions. 

Multiple levels of security zones may be used, due to the heavyweight 
implementation necessary to enforce the higher levels of security (capabilities & 
encryption). If the message transport supports (or helps support) these security levels, the 
support may be leveraged to provide security level bridge services that bridge one level of 
security to another. 

As mentioned above, services without any security model may accept empty 
authentication credentials. For services that do not restrict access, a gate may be built 
without an authentication credential or with an "empty" authentication credential. The 
gates for such services may not send an authentication credential with each message, or 
may send an empty credential. The authentication service is one example of a service that 
may not restrict access. Other services may require a user and password pair. 

In some embodiments, a mechanism for verifying that a client attempting to run a 
service, for verifying that the service advertisement received by the client is an authorized 
service advertisement, and for verifying that the space from which the client received the 
service advertisement is authorized may be based upon a public key/private key 
asymmetric cryptographic mechanism. In this mechanism, an authorized sending entity 
may embed a public key in a message and encrypt the message including the public key 
with its private key. An entity receiving the encrypted message may decrypt the message 
using the public key and find the same public key embedded in the decrypted message, 
and thus verify that the message is from the authorized entity, since only that entity has 
the private key necessary to encrypt the message. Thus, an entity may issue a credential 
that is substantially unforgeable, and that other entities may decrypt (with the appropriate 
public key) to verify messages sent by the entity. 
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In one embodiment, messages in the distributed computing environment may 
include several layers of encrypted public keys for authorizing the entities in the client- 
service conmiunications model. In this embodiment, a service may build a credential CI 
including its public key XL The service may then encrypt the credential using its private 
key Yl. The service may include the encrypted credential CI in a space as part of its 
service advertisement. The space then may build a new credential C2 including 
credential CI and the space's public key X2. The space may then encrypt the credential 
C2 with its private key Y2. When a client requests the service from the space, the space 
sends the service advertisement and credential C2 to the client. When the client 
constructs a gate, it has the gate send messages to the service including another credential 
C3 which includes encrypted credential C2 and the client's public key X3, and is 
encrypted using the client's private key Y3. The client's public key X3 and the space's 
public key X2 may also be sent with the messages. 

After the gates are created, the client may send a message including encrypted 
credential C3 and public keys X2 and X3 to the service. When the service receives the 
message, it may decrypt credential C3 using the received client's public key X3 and 
check the public key X3 embedded in the decrypted credential C3 against the received 
public key X3 used to decrypt the message, thus verifying the message is from an 
authorized client. The service may then decrypt credential C2 (extracted from decrypted 
credential C3) with the received space public key X2, and check the public key X2 
embedded in the decrypted credential C2 against the received public key X2, thus 
verifying that the credential C2 is from an authorized space. Finally, the service may 
decrypt credential CI (extracted from decrypted credential C2) with the service's public 
key XI, and check the decrypted credential to verify that the credential was created by the 
service (the credential should include the public key of the service). 

Various key generation algorithms may be used, because the composition of keys 
may be hidden from both clients and services. 
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A Kerberos ticket is one example of a security credential that may be used in the 
distributed computing environment. Kerberos is a secure method for authenticating a 
request for a service in a computer network. Kerberos lets a user request an encrypted 
"ticket" from an authentication process that can then be used to request a particular 
service. The user's password does not have to pass through the network. 

Mechanisms may be provided by the distributed computing environment to 
substantially guarantee that messages sent between clients and services are not 
compromised. In one embodiment, a sender may embed a token containing information 
that may be used by the receiver to verify that the message has not been altered. There 
are several methods for generating the information to embed in the message. In one 
embodiment, a hash of the message may be computed and sent with the message. 
Hashing may include the transformation of a string of characters into a usually shorter 
fixed-length value or key that represents the original string. Upon receiving the message, 
the receiver may recompute the hash and check it against the sent hash. If the message 
has been altered, it is highly unlikely that the same hash will be generated. The sender 
may encrypt the hash and send the corresponding public key in the encrypted message to 
substantially ensure that the hash is not compromised. 

In other embodiments, an error detection scheme such as cyclic redundancy 
checking may be used. Cyclic redundancy checking is a method of checking for errors in 
data that is transmitted on a communications link. In an embodiment using cyclic 
redundancy checking, the sender applies an n-bit polynomial to the message and appends 
the resulting cyclic redundancy code (CRC) to the message. The receiver applies the 
same polynomial (which may also be passed in the message) to the message and 
compares its result with the result appended by the sender. If they agree, the message has 
been received successfully. If not, the sender may be notified to resend the message. 
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Gate factories may also play a role in security, since a gate factory may be 
"trusted" code. Using a trusted gate factory to generate gates may help to ensure that 
gates are trusted code, and that the code is correct with respect to the service 
advertisement. Clients may be required to present a client ID token or credential to the 
gate factory as a means of authentication. Services may present a service ID token or 
credential to clients (e.g. through an advertisement) when a client wishes to create a gate. 
As discussed herein, a client and service token pair may be used to create a third 
credential that may be used to allow the client to send messages to the service. This third 
credential may be referred to as an authentication credential. An authentication credential 
may be created by an authentication service during the authentication process. In one 
embodiment, the service may use any authentication policy at its disposal. In one 
embodiment, the authentication service administers the authentication policy on behalf of 
the service, and thus the service does not have to be aware of the particular authentication 
policy being used. 

The client may construct its gate using an authentication credential that the client 
receives by running an authentication service specified in the service advertisement. This 
may allow the constructed gate to send the authentication credential with each message to 
the service. When the service receives the first authentication credential in a first 
message from the client, the service may use the authentication service specified in the 
service advertisement to authenticate the client, and thus may estabhsh a binding of the 
authentication credential to the identity of the client. 

As previously discussed, some results produced by a service may be advertised in 
a space and ultimately accessed using a results gate. The results gate may or may not 
contain the same security credential as the input gate used to generate the results. 
Because input to a service may be asynchronous from its output (the results), the results 
may have a different set of access rights associated with it. For example, a payroll service 
may allow a different set of clients to initiate payroll than to read the payroll service's 
results (paychecks). Thus, a client may have to go through a separate authentication 
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process to obtain access rights to the results, which may include receiving an 
authentication credential for the results from an authentication service specified in an 
advertisement for the results. 

Message gates may offload most security checks from services. Services may 
focus on providing capability and authenticating clients. A principle of least privilege 
may be supported by giving clients access to only those capabilities that are requested (or 
assigned). 

Security checks may occur when a gate is created and/or when a gate is used 
(when messages are sent and/or received). When a client requests access to an advertised 
item (service), the process of gate creation may begin. During this process, the client gate 
factory may work with the service to mutually authenticate each other. The checks 
performed at gate creation time may be extensive, and may minimize the number of 
checks performed during gate usage. After the service has authenticated the client, the 
service may determine specific capabilities for the client (e.g. what the client is allowed to 
do on the service), and associate the capabilities with the client's authentication 
credential. These specific capabilities may specify what operations the client is allowed 
to perform on the service. Since the gates may ensure that every message contains the 
authentication credential, the service can then check each request when it is received 
against the capabilities of the authenticated client. 

Gate creation checks may ensure that a client has permission to use some or all of 
the service capabilities designated by the XML message schema. In one embodiment, 
these checks may be implemented using access control lists (ACLs) in conjunction with 
an authentication service such as Kerberos. A challenge-response sequence (such as a 
password) may also be used to authenticate a client. 

In one embodiment, whatever means is used to authenticate the client, the 
authentication may be invisible to both the client and service, the gate factory may be 
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aware of which authentication service to use, and the authentication service handles the 
authentication mechanism and policies. Gate factories may be product and environment 
dependent, or may even be controlled by a configuration management system. In one 
embodiment, the degree and method of client isolation may be platform dependent, but is 
known to the gate factory. In some embodiments, a hardware-based physical 
identification method may be used to authenticate the client. For example, the user may 
supply a physical identification such as a smart card for identification and authorization. 
Other mechanisms for authentication may be used in other embodiments. 

Message gates in the distributed computing environment are typically associated 
with a single client. The means of association may be determined by the gate factory. 
The checks performed at message send time may ensure that the proper client is using the 
gate. In one embodiment, gates may be passed in messages, and may be cloned if a new 
client wishes to use the gate. The cloning process may perform a new set of creation 
checks. 

Once a client of a space (the client may be another service) finds the 
advertisement of a space service, the client of the space may run the space service, as it 
would any other service. Running a space service may involve using an authentication 
mechanism. Running a space service may include, but is not limited to: 

1. The client of the space may first run an authentication service that may 
be specified in the service advertisement of the space service to obtain 
an authentication credential. 

2. The client of the space may use the authentication credential, the XML 
schema of the space (from space's service advertisement), and the URI 
of the space (from space's service advertisement) to construct a gate for 
the space. In one embodiment, the client may pass the information to a 
gate factory to construct the gate. 
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3. The client of the space may mn the space service by using the gate to 
send messages to the service. 

4. When the space service receives the first message from the client, with 
the authentication credential embedded, the space service may use the 
same authentication service used by the client to obtain the 
authentication credential to authenticate the client, thus establishing 
the client's identity. 

5. The space service may then determine the client's capabilities (e.g. 
what the client is allowed to do on the space service) and bind the 
capabilities to the authentication credential. 

As discussed in the Spaces section, a space's facilities may include an interface 
for spawning an empty space with substantially the same functionality (same XML 
schema) as the space from which it is spawned. The spawning facility may be useful, 
among other things, for dynamically generating spaces for results. When a requestor has 
spawned a space, only the requestor may be allowed to access the spawned space. For 
example, the spawned space may be for storing results from a service that the client needs 
to keep secured. This security may be ensured by: 

• Creating an initial root authentication credential, and initializing the 
authentication service of the spawned space, so that the authentication service 
only authenticates the root authentication credential, and so that it returns no other 
authentication credentials (no other clients of the spawned space allowed 
initially). 

• Initializing the security policies of the spawned space so that the root identity 
associated with the root authentication credential has access to all facilities of the 
space, including the security administration facilities. 

• Returning the root authentication credential and the service advertisement of the 
spawned space to the requestor of the spawned space. 



Atty. Dkt. Na: 5181-66100 



120 



Conley Rose & Tayon, P.C. 



The requestor may build a gate to access the spawned space, since it is returned 
the authentication credential and the service advertisement of the spawned space. In one 
embodiment, only the requestor and clients or services that the requestor passes the 
authentication credential and the spawned space's service advertisement may access the 
spawned space. Such linniting of access to the spawned space may be useful when a 
client and service are using that spawned space to store results, for example, if the client 
and service desire to keep the results private. 

After running a service, the client may change the authentication policies of the 
spawned space using a security administration space facility, and other clients or services 
may then access the spawned space. In addition, the spawned space's service 
advertisement may be made available to other clients of the spawned space (the other 
clients may be services) using the discovery protocol or other means. 

The message transport layer in a distributed computing environment may include 
mechanisms for protecting the security and integrity of communications among clients 
and services during transport. This security may be referred to as "wire security" or 
"transport security" to distinguish it from the authentication security implemented by the 
messaging system including gates. Encryption of messages may be provided at the 
message transport layer of the distributed computing environment. Services that request 
an encrypted transport may do so by tagging the XML advertisement. The gate factory 
may then create a gate (or gates) that uses a secure message transport such as those 
provided by Bluetooth and HTTPS. 

HTTPS (Secure Hypertext Transfer Protocol) is a Web protocol that encrypts and 
decrypts user page requests as well as the pages that are returned by the Web server. 
HTTPS may use a multi-bit key size (may vary from 40 to 128- bit or more) for a stream 
encryption algorithm (e.g. RC4), to provide an adequate degree of encryption for 
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commercial exchange. HTTPS may be used as a transport in the distributed computing 
environment. 

Bluetooth is an emerging peer-to-peer wireless connmunications standard. The 
Bluetooth key generation algorithms may be used in the distributed computing 
environment. Bluetooth may support encryption keys. Encryption keys are transport 
dependent, while client, service, and combination keys may be transport independent. 

Figure 26a - An authentication service providing an authentication credential to a client 

Figure 26a is a flow diagram illustrating an authentication service providing an 
authentication credential to a client according to one embodiment. A client in the 
distributed computing environment may desire a service to perform one or more functions 
on behalf of the client. In one embodiment, an authentication service may be provided 
for use by the client and the service when setting up a secure messaging channel. An 
authentication service may perform functions for the client and/or service including 
authenticating the client and/or service and negotiating the desired level of security and 
the set of messages that may be passed between the client and service. The 
authentication service may be a process that is executing within the distributed computing 
environment. The authentication service may be executing on the same device as the 
service and/or the client, or alternatively the authentication service may be executing on a 
separate device such as an authentication server. In one embodiment, the authentication 
service may be an Internet-based service. The authentication service may have its own . 
address, for example, a Universal Resource Identifier (URI), through which the client 
and/or service may communicate with the authentication service. In one embodiment, the 
address of the authentication service may be provided to the client in the service 
advertisement for the service. The client and service sharing an authentication service 
may help insure that a secure messaging channel may be established between the client 
and the service, as any of several security and authentication protocols may be used in the 
messaging channel. 
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In one embodiment, a client may present a client identification token or credential 
to an authentication service. The client token or credential may be sufficiently 
unforgeable to be used as proof of the client's identity. The authentication service may 
5 then check the client identification token or credential, and issue to the client an 
authentication credential that only the authentication service can create. The 
authentication credential that is returned to the client is then sent in every message by the 
client to the service. In one embodiment, the client message gate is created by a gate 
factory, which includes the authentication credential in the message gate, and thus the 
10 message gate includes the authentication credential in every message that it sends to the 
service on behalf of the client. When receiving a message, the service may then check the 
authentication credential. Since only the authentication service can create the 
authentication credential, the service knows that the client did not forge the authentication 
credential. In one embodiment, the service may pass the authentication credential to the 
^ 15 same authentication service used by the client to ensure the authentication credential is 

valid, to verify that the client is an authorized cUent, and to find out the identity of the 
client. 



n 



All services, including space services and authentication services, may 
20 authenticate their clients. Once a service authenticates a client, the client may access the 
service. For example, in the case of a space service, a client may then obtain XML 
advertisements from the space. 

In one embodiment, a service may have a prearranged credential that all clients of 
25 the service are to use. In this embodiment, the authentication may provide the 
prearranged credential to a requesting client. Any client presenting the prearranged 
credential to the service may be approved by the service. 

In step 1000, the client may request an authentication credential from the 
30 authentication service. In one embodiment, the client may search for and locate a service 
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advertisement for the desired service. In one embodiment, the service advertisement may 
include an advertisement for the authentication service to be used to obtain an 
authentication credential to be used in accessing the service. In one embodiment, the 
service advertisement may include an address such as a URI for the authentication 
service. In one embodiment, the client may send information to the authentication service 
requesting the authentication credential. In one embodiment, the client may send 
information to a gate creation process, for example, a gate factory, and the gate creation 
process may access the authentication service to obtain the authentication credential. 

In step 1002, the authentication service may generate an authentication credential 
for the client. The authentication credential may be a data element or data structure that 
may be embedded in messages in a messaging system and that may allow receivers of the 
messages to authenticate the sender of the message, to verify the message is from an 
authorized sender, and to verify that the message is a message the sender is allowed to 
send to the receiver. In one embodiment of a distributed computing environment, an 
authentication credential may be unique to the messaging channel set up between a 
particular client and a particular service. Step 1002 is further illustrated and described in 
Figure 26b. In step 1004 of Figure 26a, the authentication service may return the 
authentication credential to the client. In one embodiment, the authentication credential 
may be returned directly to the client. In one embodiment, the authentication credential 
may be returned to a gate creation process, for example, a gate factory, which may then 
use the authentication credential in generating a gate. 

Figure 26b - An authentication service generating an authentication credential 

Figure 26b is a flow diagram expanding on step 1002 of Figure 26a and 
illustrating an authentication service generating an authentication credential according to 
one embodiment. In step 1002a, in one embodiment, the authentication service may 
obtain a client token and a service token. In another embodiment, the authentication 
service may obtain only a client token. In one embodiment, the client token may be a 



Atty, Dkt, No.: 5181-66100 



124 



Conley Rose & Tayon, P.C, 



unique identifier for the client in the distributed computing environment. In one 
embodiment, the service token may be a unique identifier for the service in the distributed 
computing environment. For example, the public keys from a public/private key 
encryption mechanism may be used as unique identifiers for the client and the service. In 
one embodiment, the client may receive the service token in the service advertisement, 
and the client may provide the client token and the service token to the authentication 
service. In another embodiment, the client may provide the client token and the service 
advertisement URI to the authentication service, and the authentication service may 
retrieve the service token from the service advertisement. 

In step 1002b, the authentication service may verify the client and/or the service. 
In one embodiment, the authentication service may use the client token and the service 
token obtained in step 1002a to verify the client and/or service. In another embodiment, 
only a client token was obtained in step 1002a, and thus only the client token is used to 
verify the client in step 1002b. In one embodiment, the client may have previously 
registered its client token with the authentication service, and the authentication service 
may compare the received client token to the registered client token to verify the client as 
a valid client. In one embodiment, the client may access the authentication service using 
a challenge/response mechanism such as a logon account with password and thus may be 
verified as a valid client. In one embodiment, the service may have previously 
registered with the authentication service, and may have provided its service token to the 
authentication service. The authentication service may then verify that the client is 
attempting to access a valid service by comparing the received service token to the 
previously registered service token. Other types of client and service authentication may 
also be used. For example, the client may provide a digital signature or digital certificate 
that the authentication service may use to authenticate the client and/or to authenticate the 
service the client is trying to access. 

In step 1002c, the authentication service may generate an authentication 
credential. In one embodiment, the authentication credential may include an 
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authentication token that only the authentication service can create. In one embodiment, 
the authentication service may use the client token and the service token in generating the 
authentication credential. In another embodiment, the authentication service may use just 
the client token to generate the authentication credential. In yet another embodiment, the 
authentication service may not use an obtained token in the generation of the 
authentication credential, but may instead use an authentication credential generation 
algorithm to generate a substantially unforgeable authentication credential. In one 
embodiment, the authentication service may combine the service token and client token to 
create a unique authentication credential. For example, the service token and client token 
may be 64-bit values, and the two tokens may be combined to generate a 128-bit 
authentication credential. Other embodiments may use other methods to generate an 
authentication credential. 

Figure 41 - Creating a gate 

Figure 41 is a flow diagram illustrating the creation of a gate for a client according 
to one embodiment. In one embodiment, a gate factory may be trusted code on the client 
for generating gates based on XML service descriptions. In another embodiment, the gate 
factory may reside on a separate device and may be used by the client to generate gates. 
For example, a gate factory service may be accessible by the client go generate gates. The 
use of the gate factory may ensure that generated gates are trusted code, and that the code 
is correct with respect to the service advertisement. 

Security checks performed at gate creation time may be extensive, and thus may 
minimize the number of security checks that need to be performed during gate usage. 
Security checks during gate creation may help ensure that a client has permission to use 
the set of service capabilities designated in the message schema retrieved from the service 
advertisement. In one embodiment, the security checks may be implemented using 
Access Control Lists (ACLs) in conjunction with an authentication service. In one 
embodiment, a challenge/response sequence (such as a logon and password account) may 
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be used to authenticate a client. In one embodiment, the client authentication and gate 
creation security checks may be hidden from the client and service, the gate factory may 
only be aware of the authentication service to be used, and the authentication service may 
be aware of the authentication mechanism and policies. 

In step 1010, the gate factory may obtain an authentication credential for the client 
to use in communicating with a service. In one embodiment, the client may have 
previously obtained the authentication credential from an authentication service and may 
then provide the authentication credential to the gate factory. In another embodiment, the 
gate factory may obtain the authentication credential from the authentication service. 

In one embodiment, the gate factory may also obtain a message schema for the 
service. In one embodiment, the gate factory may obtain the message schema from the 
client. In another embodiment, the gate factory may receive the message schema from a 
service advertisement. For example, the client may supply a URI for the service 
advertisement to the gate factory, and the gate factory may connect to the service 
advertisement using the URI to obtain the message schema. The message schema may 
describe the set of messages that may be sent to or received from the service. For 
example, messages may be described that may be sent from a client to a service to invoke 
the service or to invoke aspects of the service. Messages may also be described that may 
be sent from the service to the client, such as response messages and event notification 
messages. In one embodiment, the messages may be XML messages, and the message 
schema may be an XML message schema. 

In step 1012, the gate factory may generate a client message gate. In one 
embodiment, the gate factory may embed the authentication credential as data in the 
generated message gate so that the message gate code may access the authentication 
credential. In another embodiment, the authentication credential may be stored externally 
to the message gate on the client. In one embodiment, a URI for the service may also be 
embedded in or provided to the gate by the gate factory. 
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In step 1012, the gate factory may also use the message schema in generating the 
client message gate. The message schema may be used to define the set of messages that 
the client may send to the service through the message gate. The gate factory may 
compile the message schema into the gate. The message schema may be compiled by the 
gate factory into the gate in an internal form suitable for quick access during the message 
verification process. Access to a service may be restricted for a particular client using the 
schema, thus giving the client less than full access to the service. In one embodiment, 
when the client obtains the service advertisement, for example, from a space, based upon 
the capabilities and/or access rights of the client, a restricted message schema may be 
provided to the client for the service. Thus, the gate factory may compile a restricted 
message schema into the client message gate, thus restricting the client's access to the 
service. In one embodiment, the authentication service may determine a subset of the 
total set of messages that the client may send to the service. One or more levels of access 
may be provided for a service in the distributed computing environment. One level of 
access may provide a client of the service with access to all of the request messages in the 
message schema for the service, and thus to substantially all of the functions provided by 
the service to clients in the distributed computing environment. Other levels may provide 
a client of the service with access to various subsets of the request messages in the 
message schema, and thus to various subsets of the functionality of the service. In one 
embodiment, levels of access may also be determined by a client's capabilities. For 
example a thin cUent may not be able to download large data files, and thus may be 
restricted from using a message requesting the download of a large data file. 

In one embodiment, the client may provide information about the client to the 
authentication service to determine an access level for the client. In one embodiment, the 
information may include a request for a specific level of access to the service. In one 
embodiment, the gate factory may provide the information to the authentication service to 
determine the access level of the client. Thus, the gate factory may generate a client 
message gate that is capable of sending a subset of the entire set of messages described in 
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the message schema to the service based upon the capabilities and/or access level of the 
client. 

In step 1014, the gate factory has generated the client message gate, and may 
5 notify the client that the gate has been generated. In one embodiment, the client message 
gate is a distinct code module that is accessible by the client. In one embodiment, the 
client message gate resides on the client. The client may then generate messages and pass 
the messages to the client message gate, which may verify the messages and send the 
messages to the service. Embodiments of a gate pair mechanism for the client and 
10 service to exchange messages is further described in Figures 42a-42c. Embodiments of 
gate factories are further described elsewhere herein. 



A gate comprises code and data, and thus may itself be passed in a message. This 
provides an alternative method for creating gates on clients and/or services. In one 



03 

U 15 embodiment, a gate passed in a message may be cloned if a new client wishes to use the 

m gate. The cloning process performs a new set of gate creation security checks including 

^ authentication of the new client. A new, unique authentication credential may be 

1=^ generated for the new client and embedded in the cloned gate. 

i; 20 Figure 42a - A client sending a message to a service 

O 

Figure 42a is a flow diagram illustrating a client sending a first message to a 
service according to one embodiment. In step 1020, the client may send a message to the 
client message gate. In one embodiment, the message may be an XML message. In step 
25 1022, the message gate may embed an authentication credential in the message prior to 
sending the message. In one embodiment, the authentication credential may have been 
provided by an authentication service as part of gate construction as described above. 

In one embodiment, the message gate may verify the data representation language 
30 type correctness, syntax, etc. of the message. In one embodiment, the message gate may 
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compare the message to a message template in a data representation language message 
schema to determine data representation language type correctness of the message. In 
one embodiment, the message may be an XML message, and the message gate may check 
the message against an XML message schema. In one embodiment, the message schema 
may have been provided by an authentication service as part of gate construction as 
described above. In one embodiment, the message gate may locate a message template 
for the message in the schema and compare the various items or fields in the message to 
the message template to determine type correctness of the items. 

In one embodiment, the first message may be a request message received from the 
client to be sent to the service, and the message gate may determine if the message and/or 
the requested service function(s) specified by the message are in the allowed subset of 
messages and/or service functions the client may send to the service. In one embodiment, 
the message gate may compare the message to the subset of allowed messages in the 
message schema to determine if the message is allowed. In one embodiment, an access 
level to the service provided to the client by the authentication service may be used to 
determine the subset of allowed messages the client may send to the service. In one 
embodiment, the first request message may request the service to establish a 
communications channel with the client. In one embodiment, the conmiunications 
channel comprises a gate pair. The gate pair may comprise a client message gate and a 
service message gate. In one embodiment, the service message gate may not exist on the 
service when the first message is sent to the service. 

In step 1024, the cHent message gate may send the first message to the service 
over the communications channel connecting the client to the service. In one 
embodiment, the client message gate may send the message to a service URL In one 
embodiment, the service URI may have been provided to the client in the service 
advertisement. In one embodiment, the client message gate may be created for a specific 
service URI so that all messages are sent to the specific service URI, thus creating a 
message channel from the client to the service. In one embodiment, the request message 
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may include an address for the client message gate so that the service may establish a 
communications link to the client through the client message gate. Examples of 
addresses that may be used for message gates include, but are not limited to: Universal 
Unique Identifiers (UUDDs) or URIs. The process of a service receiving a first message 
from a client is illustrated and described in Figure 42b. 

Figure 42b - A service receiving a message from a client 

Figure 42b is a flow diagram illustrating a service receiving a message from a 
client and using an authentication service to authenticate the message according to one 
embodiment. In step 1030, the service may receive a first message from the client. In 
one embodiment, the service message gate may not exist on the service when the first 
message is received by the service. In one embodiment, the client message gate may send 
the first message to a URI at the service, and the service may receive the first message 
from the client and then may generate a service message gate. In one embodiment, a 
mechanism on the service may be configured to generally receive messages including 
messages from clients at a URI provided to the cHent in the service advertisement. Upon 
receiving a first message from a client, the service may generate a service gate to thus 
establish a communications channel with the client through the gate pair consisting of the 
service message gate and the client message gate. In one embodiment, an address (for 
example, a UUID or URI) for the client message gate may be provided to the service in 
the first message from the client and may be used in generating the service message gate. 
In one embodiment, the service message gate may communicate only with the client 
message gate and thus with the client associated with the message gate. Thus, in some 
embodiments, there may be at least one unique service message gate for each client that is 
currently in communication with the service. 

As described above, the client message gate may have embedded an 
authentication credential in the first message sent to the service. In step 1032, the service 
may send the authentication credential to an authentication service. In one embodiment. 
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the authentication service may be the same authentication service used by the client to 
generate the authentication credential. In one embodiment, the service message gate may 
send the authentication credential to the authentication credential. In one embodiment, 
the entire message may be sent to the authentication service. 

In step 1034, the authentication service may perform verification of the 
authentication credential. In one embodiment, the authentication service may include a 
copy of the authentication credential from the creation of the authentication credential. In 
one embodiment, the authentication service may compare the authentication credential 
received from the service with the copy of the authentication credential. If the 
authentication credentials match, in step 1036, the authentication service may notify the 
service that the authentication credential has been verified and appears to be valid. If the 
verification process fails, the authentication service may notify the service that the 
authentication credential appears to be invalid. 

In one embodiment, the authentication service may establish an access level for 
the client to access the functionality of the service. In one embodiment, the client may 
have established an access level for the service with the authentication service. In one 
embodiment, the authentication service may notify the service of the access level of the 
client. The access level of the client may be used by the service to determine a subset of 
request messages as described in the service message schema that the client may send to 
the service. 

In step 1038, if the authentication service notified the service that the 
authentication credential is valid in step 1036, the service may generate a service message 
gate to pair with the client gate to form a gate pair. The service message gate may include 
the authentication credential to embed in messages sent from the service to the client, and 
for comparison with the authentication credential in messages received from the client. 
The service message gate may also include an address (such as a UUID or URI) for the 
client message gate. The service message gate may also include access level information 
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for the client for verifying that messages received from the client are in the subset of 
allowed messages the client may send to the service. The service message gate may also 
include a message schema for type checking and verifying the syntax of messages 
received from the client and for use in verifying if messages are in the allov^ed subset of 
messages. In one embodiment, the service may create a new service message gate. In 
another embodiment, a service message gate may already exist prior to step 1038 that 
may be used to generate the service message gate to conmiunicate with the client. In this 
embodiment, the service may not create a new gate, but instead may update the existing 
gate with information about the message channel to be established between the client and 
the service. 

In one embodiment, after the service generates the service message gate, the 
service may send a message to the client. The message may include information to 
identify the service message gate to the client message gate and thus to establish the 
communications channel between the client and the service using the message gate pair. 
In one embodiment, the message may include an address (such as a UUID or URI) for the 
service message gate. 

Figure 42c - Exchanging messages with embedded authentication credentials 

Figure 42c is a flow diagram illustrating the general process of a client and service 
exchanging messages with embedded authentication credential according to one 
embodiment. In one embodiment, after the cHent message gate and the service message 
gate are established, the client and service may no longer require the services of the 
authentication service. When sending messages, the client and service message gates 
may embed the authentication credential in the messages. When receiving messages, the 
client and service message gates may verify the message by comparing the embedded 
authentication credential with the copy of the authentication credential included in the 
gate. 



Atty. Dkt. No.: 5181-66100 



133 



Conley Rose & Tayon, P.C. 



In step 1040, the sender (client or service) message gate may embed an 
authentication credential in a message prior to sending the message. In one embodiment, 
the authentication credential may have been provided by an authentication service. In one 
embodiment, the message may be an XML message. 

In one embodiment, the sender message gate may also verify the data 
representation language type correctness, syntax, etc. of the message prior to sending the 
message. In one embodiment, the sender message gate may compare the message to a 
message template in a message schema to determine type correctness of the message. 
For example, the message may be an XML message, and the message gate may include an 
XML message schema. The sender message gate may locate a message template for the 
message in the schema and compare the various XML items or fields in the message to 
the message template to determine type correctness of the items. 

In one embodiment, the sender message gate may check the allowability of the 
message. In one embodiment, the message may be a request message received from a 
client to be sent to a service, and the message gate may determine if the requested 
function(s) specified by the message are in the subset of functions provided to the client 
by the access level the client established with the service through the authentication 
service. In one embodiment, the message gate may compare the message to a subset of 
allowed request messages in a message schema to determine if the message is allowed. In 
one embodiment, if the message is a response message from a service to a client, the 
message may not be checked for allowability. In another embodiment, response messages 
from the service to the client may be checked by the client message gate to insure that the 
client is authorized to receive the response message. 

In step 1042, the sender (client or service) message gate may then send the 
message to the destination (client or service) message gate over the communications 
channel connecting the source (client or service) to the destination (client or service). In 
one embodiment, when receiving the message, the receiver message gates may verify the 
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sender of the message by comparing the embedded authentication credential with the 
copy of the authentication credential included in the gate. 

In one embodiment, the message may be encrypted before sending. In one 
embodiment, the message gate may perform the encryption. In another embodiment, the 
encryption may be performed by a process external to the message gate. For example, the 
message gate may pass the completed message to a driver process for a communications 
channel, and the driver process may perform encryption of the message. In one 
embodiment, encryption and decryption of messages may be performed by a transport 
mechanism (e.g. HTTPS). 

In step 1044, the receiver (client or service) message gate may receive the 
message sent in step 1042. In one embodiment, if the message is encrypted, the message 
may be decrypted by a process prior to being received by the message gate. In another 
embodiment, if the message is encrypted, the message gate may decrypt the message. In 
step 1046, the receiver message gates may authenticate the sender of the message by 
comparing the embedded authentication credential with the copy of the authentication 
credential included in the receiver gate. 

In some embodiments, some services may not require authentication credentials 
for at least some clients. In one embodiment, a client wishing to access a service for 
which no authentication credential is required for the client may generate a message gate 
without using an authentication service. In another embodiment, an authentication 
service may return a null, empty or otherwise generic authentication credential to a client 
that does not require authentication to use a service. In one embodiment not requiring 
authentication, the message gates may send messages without embedding authentication 
credentials. In another embodiment, a null, empty or otherwise generic authentication 
credential may be embedded in messages by the message gates. 
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In one embodiment, the receiver message gate may verify the data representation 
language type correctness, syntax, etc. of the message upon receiving the message. In one 
embodiment, the receiver message gate may compare the message to a message template 
in a message schema to determine type correctness of the message. For example, the 
5 message may be an XML message, and the message gate may include an XML message 
schema. The receiver message gate may locate a message template for the message in the 
schema and compare the various XML items or fields in the message to the message 
template to determine type correctness of the items. 



m 



10 In one embodiment, the receiver message gate may check the allowability of the 

message. In one embodiment, the message may be a request message received from a 
client, and the message gate may determine if the requested function(s) specified by the 
message are in the subset of functions provided to the client by the access level the client 
established with the service through the authentication service. In one embodiment, the 

15 receiver message gate may compare the message to a subset of allowed request messages 
in a message schema to determine if the message is allowed. 



'f^^ In one embodiment, the message may be verified for type correctness and/or 

allowability by the sender and the receiver. In another embodiment, the sender may 

0 20 perform message verification. In yet another embodiment, the sender may not perform 

O 

™ message verification, and the receiver may perform message verification. In still yet 

another embodiment, no verification may be performed. 



Some cHents may be too "thin" to support the full functionality of a client 
25 message gate. These clients may not perform some or all of the request message 
verification prior to sending request messages and the response message verification 
subsequent to receiving response messages as described above. For example, some 
simple client devices may include a small set of request messages that may be sent to a 
service, and a small set of responses that may be accepted from the service. In one 
30 embodiment, a minimal client message gate may be constructed for the client device that 
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sends request messages and receives response messages without performing the message 
verification as described above. In another embodiment, a proxy client message gate may 
be set up on another device that may provide some or all of the message verification, 
sending, and receiving as described above for the client. 

Figure 43 - Checking the integrity of messages 

Figure 43 is a flow diagram illustrating a mechanism for checking the integrity of 
messages according to one embodiment. In step 1050, the sender gate, acting on behalf 
of a client or a service, may embed a token in a message to be sent. This token is separate 
and distinct from the authentication credential as described above. The token may 
include information allowing the receiving gate to verify that the message has not been 
compromised or altered. For example, the sender may compute a hash or checksum of 
the message that may be verified by the receiver. The sender may also encrypt this token 
and/or the entire message using the sender's private key and include in the encrypted 
message the corresponding public key so that the receiver may verify that the token was 
not changed. In step 1052, the sender gate may send the message. In step 1054, the 
receiver gate, acting on behalf of a service or a client, may receive the message. In step 
1056, the receiver gate may examine the message, and the embedded token, to verify that 
the message has not been compromised. 

There are several methods for generating the token to embed in the message. In 
one embodiment, a hash of the message may be computed and sent with the message. 
Hashing may include the transformation of a string of characters into a usually shorter, 
fixed-length value or key that represents the original string. Upon receiving the message, 
the receiver may recompute the hash and check it against the sent hash. If the message 
has been altered, it is highly unlikely that the same hash will be generated. The sender 
may encrypt the hash and send the corresponding public key in the encrypted message to 
substantially ensure that the hash is not compromised. 
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In other embodiments, an error detection scheme such as cycHc redundancy 
checking may be used. CycHc redundancy checking is a method of checking for errors in 
data that is transmitted on a communications link. In an embodiment using cyclic 
redundancy checking, the sender applies an n-bit polynomial to the message and appends 
the resulting cyclic redundancy code (CRC) to the message. The receiver applies the 
same polynomial (which may also be passed in the message) to the message and 
compares its result with the result appended by the sender. If they agree, the message has 
been received successfully. If not, the sender may be notified to resend the message. 

Other embodiments may include other methods for generating, embedding and 
checking tokens for checking messages for errors or malicious tampering. 

Bridging Devices to the Distributed Network Environment 

There may be devices, external to the distributed computing environment, which 
do not support the message passing model implemented by the distributed computing 
environment. These devices may provide services that may be useful to clients in the 
distributed computing environment. The distributed computing environment may include 
a mechanism to bridge such external devices to the distributed computing environment so 
that the services offered on such devices may be accessed by clients in the distributed 
computing environment. The distributed computing environment may also leverage 
existing device discovery protocols for discovering such external devices for use in the 
distributed computing environment. 

Many technologies define discovery protocols for publishing and monitoring a 
network's device composition. These technologies include, but are not limited to: Jini, 
SLP, Bluetooth, and UPnP, Furthermore, many I/O buses such as LonWorks, USB and 
1394 also support dynamic discovery protocols. The distributed computing environment 
may leverage device discovery technologies by wrapping their implementations in an 
API. Leveraging other device discovery protocols and providing a method to bridge to 
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other discovery protocols may allow the distributed computing environment to discover 
devices or services on a wide variety of network and I/O buses. Device discovery in the 
distributed computing environment may thus be applicable to a wide range of devices 
including small devices such as PDAs, even if they do not participate directly in the 
distributed computing environment. Discovery protocols may be defined at the message 
level. 

A bridging mechanism may be provided for "wrapping" one or more specific 
device discovery protocols, such as Bluetooth 's, in a messaging API for the distributed 
computing environment. Wrapping may include framing the device discovery protocol 
with code and/or data (the API) so that the protocol can be run by clients and/or services 
in the distributed computing environment that would not otherwise be able to run it. 
When run, the bridging mechanism may allow for a discovery agent that discovers 
devices by a specific device discovery protocol to publish services for those devices in a 
space in the distributed computing environment. The services present an XML message 
schema interface to clients in the distributed network environment, and are capable of 
operating the various devices discovered by the specific device discovery protocol. Thus, 
service advertisements may be published for the services that operate the various devices 
discovered by the underlying wrapped device discovery protocols. The advertised 
services thus bridge devices (or services) external to the distributed network environment 
to clients on the distributed network environment. 

Figure 27 illustrates one embodiment of a distributed computing environment 
with a space 1200. One or more discovery agents 1204 may participate in an external 
discovery protocol and bridge to the distributed computing environment through bridging 
mechanism 1202. When the wrapped device discovery protocols are run, discovery 
agents 1204 through bridging mechanism 1202 may publish service advertisements 
1206a-1206c in space 1200, wherein each one of advertisements 1206a-1206c 
corresponds to a device or service discovered by one of discovery protocols 1204 outside 
the distributed computing environment. Clients may then access the external devices 
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using the service advertisements 1206a-1206c in space 1200 to instantiate services on one 
of the agents 1204 that operates the corresponding external device or service. 

Thus, clients of the distributed computing environment may use discovery agents 
wrapping device discovery protocols to find devices. A service acting as a bridge to these 
devices may be published in a space and advertised, so clients of the distributed 
computing environment may access the services provided by the external devices. The 
advertised service is a service within the distributed computing environment that is able 
to invoke a device outside the distributed computing environment via another protocol or 
environment, thus bridging the outside device/service to the distributed computing 
environment. A client within the distributed computing environment "sees" only the 
advertised service within the distributed computing environment and may not even be 
aware of the outside device/service. 

In one embodiment, the distributed computing environment may provide a version 
of a space discovery message protocol, such as the discovery protocol described in the 
Spaces section, that may be mapped to an underlying external device discovery protocol, 
including the wrapped device discovery protocols described above. The mapped 
discovery protocol may register itself or be registered with a space, e.g. a default space, 
by placing an advertisement in that space. For each advertised discovery protocol, a 
subsequent results space to hold the results of the discovery protocol may be provided. 

Figure 28 illustrates an example of the space discovery protocol mapped to a 
Bluetooth discovery service 1220 according to one embodiment. The Bluetooth 
discovery service 1220 may first register 1230 with the distributed computing 
environment. The Bluetooth discovery service 1220 may be wrapped in a bridging API, 
and an advertisement 1225 for the discovery service 1220 may be added 1232 in space 
1224. A client or service may locate the discovery service advertisement 1225 on space 
1224. When the discovery service 1220 is executed (utilizing the API wrapper as a 
bridge between the discovery protocol 1220 and the distributed computing environment 
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1222), a new space 1226 may be created 1234 to store the results of the discovery 
process. The discovery service 1220 may store the results (again through the API 
wrapper) to discovery results space 1226 as one or more advertisements 1227. 
Alternatively, results of executing discovery service 1220 may be stored to space 1224 or 
other pre-existing spaces in the distributed computing environment. A similar method as 
illustrated in Figure 28 may be used to discover devices and other services using other 
underlying discovery protocols. 

As mentioned above, there may be devices, external to the distributed network 
environment, which do not support the message passing model implemented by the 
distributed network environment. These devices may have clients that may want to use 
services provided in the distributed computing environment. The distributed computing 
environment may provide a mechanism to bridge the external clients or client devices to 
the distributed computing environment so that the clients on the external devices may 
access services in the distributed computing environment. 

Agents may be provided that serve as clients in the distributed computing 
environment to bridge external clients to the distributed computing environment, 
allowing the external clients to access services published in the distributed computing 
environment. In one embodiment, an agent may have an XML-enabled back end capable 
of communicating with services in the distributed computing environment using the 
message passing model, and a proprietary protocol (e.g. a protocol supported by the 
external device) on the front end to interface to the external device, and thus to the 
external client. Thus, a client external to the distributed computing environment may 
locate and access services in the distributed computing environment through the bridging 
agent, and may send requests to the services and receive responses from the services, 
including results data. For example, an external client may use the bridging agent to run 
space discovery in the distributed computing environment, look up advertised services, 
and invoke services in the distributed computing environment. 
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In one embodiment, the distributed computing environment may provide a 
bridging mechanism for accessing Jini services from a distributed computing 
environment client. Since Jini services may require Remote Method Invocation (RMI), 
and since clients in the distributed computing environment may communicate to services 

5 using messages such as XML messages, a protocol bridging mechanism may be provided 
to enable the access of a Jini Service by a distributed computing environment client. In 
one embodiment, a connector mechanism may be defined that enables the dynamic 
advertisement of Jini services in distributed computing environment spaces, and that also 
may enable the accessing of a Jini service proxy from clients in the distributed computing 

10 environment. In one embodiment, there may be Jini services that may not be bridged to 
the distributed computing environment. 



5 In one embodiment, an agent may be provided as a service in the distributed 

n computing environment that bridges the Jini RMI protocol used by Jini services to XML 

15 messaging used by distributed computing environment clients. When the agent is started, 
the agent may perform a lookup on the Jini spaces for Jini services that have a set of 
attributes. For every registered Jini service, the agent may generate an XML 
advertisement that may correspond to the service and may register the advertisement in a 
space in the distributed computing environment. In one embodiment, an agent may 
20 register for event notification in the Jini Lookup service, and thus may be informed when 
a new Jini service is registered. When informed of a new Jini service, the agent may 
perform a lookup in Jini spaces to locate newly advertised Jini services and to update the 
distributed computing environment space with new XML advertisements for the new 
services. In one embodiment, when a Jini service is removed, the agent may receive an 
25 event notifying of the removal of the Jini service. The agent may then remove the XML 
advertisement for the service from the space. 

In one embodiment, to invoke a Jini service via an XML advertisement in a 
distributed computing environment space, a client may look up the service advertisement 
30 in the space and may send valid messages to the agent to access the service. The agent 
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may invoke the proxy service corresponding to the Jini service by invoking the 
corresponding method through an RMI call to a service proxy. If the proxy is not 
instantiated, the agent may download the proxy code and instantiate a new instance of the 
proxy object. In one environment, every client connection may have a different proxy- 
instance. The incoming message from the client may be converted by the agent into a 
method call for the proxy. The result from the method call may be returned to the client 
as an outgoing message. 

In one embodiment, only simple Java types may be used as arguments to an RMI 
method. If complex Java types are required, then one or more data advertisements may 
be passed as arguments to the call, where the data advertisements may indicate the 
location and access method of data for the complex Java types. In one embodiment, 
initial conversion from XML messages to an RMI method call invocation may be 
performed dynamically by the agent. Since, the agent knows the service interface, it may 
generate the corresponding set of messages that are advertised to the client. 

Figure 29 illustrates bridging a client 1250 external to the distributed computing 
environment to a space 1254 in the distributed computing environment. Bridging agent 
1252 may serve as the go-between between client 1250 and space 1254. Bridging agent 
1252 may communicate with client 1250 in a communications protocol understandable by 
the client 1250. Bridging agent 1252 may map the client's communications protocol into 
the XML messaging protocol necessary to communicate with space 1254 perform the 
facilities provided by space 1254. Bridging agent 1252, at client 1250's request, may 
locate and run services on space 1254. For example, client 1250 may request a list of all 
services of a particular type from space 1254. Bridging agent 1252 may locate service 
advertisements 1256a-c and return the results to client 1250. Alternatively, the results 
may be posted in a results space, and the location of the results may be returned to the 
client 1250. Client 1250 may then choose to execute service advertisement 1256a, and 
may send a message (in the client 1250's communications protocol) to bridging agent 
1252. Bridging agent 1252 may then send the XML request message(s) necessary to 
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execute the service represented by service advertisement 1256a, and may return the 
results of the service to client 1250. Methods of handling the results of the service other 
than directly returning the results to the client 1250 may be used as described above in the 
section titled Spaces. Bridging agent 1252 thus may act as a service of the external client 
5 1250 (via the external client's protocol) and as a client within the distributed computing 
environment to bridge a service within the distributed computing environment to the 
external client. 



Sometimes, even within the distributed computing environment, clients and 
10 services cannot directly communicate with each other, only to a common space. In this 
case, the space service will automatically create a service proxy that bridges client to 
service. The proxy's main job is to route messages between client and service through the 
space. The service proxy may be created dynamically. The creation mechanism may be 
dependent upon space implementation. Refer to Figure 30 for an illustration of a proxy 
15 mechanism. A client 554 and a service 556 may not be able to communicate directly 
within the distributed computing environment, e.g., because they support different 
transport or network protocols. However, they both may be able to communicate with a 
space 552 that supports both protocols. The space service may create a proxy 550 to 
bridge the client 554 to the service 556. A common form of proxy is a browser proxy. A 
20 browser proxy (most commonly implemented as a servlet) may translate conventional 
Web page requests into messages. Refer also to the description of space search services 
(and proxies therefore) in the Spaces section herein. 

The distributed computing environment may provide a mechanism for bridging 
25 clients in the distributed computing environment to enterprise services. In one 
embodiment of a distributed computing environment, a method for bridging clients to 
enterprise services may include a client within the distributed computing environment, a 
bridge service within the distributed computing environment, and an enterprise service 
within the enterprise environment. The distributed computing environment bridge 
30 service serves as a bridge service between the client and the enterprise service. 
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The bridge service interacts with the client via XML message passing to gather 
input parameters necessary to make requests to the enterprise service outside of the 
distributed network environment. For example, the bridge service may be looked up and 
instantiated by the client just as any other service in the distributed computing 
environment. The bridge service then may interact with the enterprise service to run the 
enterprise service. This interaction may use an interprocess conrununications architecture 
that the enterprise service can understand. As an example, if an enterprise service is 
implemented with Enterprise JavaBeans (EJB), a bridge service may communicate with 
the enterprise service using EJB. The bridge service may then receive results from the 
enterprise service and may return the results directly to the client (in XML messages) or 
may place the results in a space in the distributed network environment (e.g. a results 
space). To the client, the bridge service appears to be the only service (the enterprise 
service is hidden to the client), so the client does not have to support the architecture of 
the enterprise service. Multiple distributed network environment chents may use the 
same bridge service (each using a unique gate pair) to interact with the enterprise service. 

The bridge service or other agent may publish an advertisement for the bridge 
service (and thus for the enterprise service) in a space in the distributed computing 
environment. For example, a bridge service or other bridge agent may use Java 
Reflection to examine Beans for services in an enterprise system implemented with EJB, 
and then create service advertisements for bridge services to the Beans and publish those 
advertisements in spaces in the distributed computing environment. Reflection is a 
method for Java code to discover information about the fields, methods and constructors 
of classes, and to use reflected fields, methods, and constructors to operate on their 
underlying counterparts on objects, within security restrictions. The Reflection API 
accommodates applications that need access to either the public members of a target 
object or the members declared by a given class. Once the bridge services are advertised, 
clients may access the bridge services (and thus the corresponding enterprise services) 
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similarly to any other advertised services in the distributed network environment, without 
knowledge of the architecture of the enterprise service providing the services. 

Client Displays 

There are several methods in which results from a service run by a client may be 
displayed in a distributed computing environment. Devices that may display results may 
include, but are not limited to: CRTs on computers; LCDs on laptops, notebooks 
displays, etc; printers; speakers; and any other device capable of displaying results of the 
service in visual, audio, or other perceptible format. The methods for displaying results 
may include, but are not limited to: 

• The service may return results to a client directly or by reference, and the 
client may handle the display of the results. 

• The service may return results to a client directly or by reference, and the 
client may pass the results to a display service directly or by reference, and 
the display service may display the results. 

• The service may directly handle the displaying of the results. 

• The service may pass the results to a display service directly or by 
reference, and the display service may display the results. 

Figure 31 illustrates one embodiment of a client 1300 with associated display 
1302 and display service 1304 according to one embodiment. 

Conventional application models are typically based on predetermined, largely 
static user interface and/or data characteristics. Changes to conventional applications 
may require code modification and recompilation. The mechanisms described for 
advertising services and for specifying XML message schemas for conmiunicating with 
services in the distributed computing environment may be used to provide a mechanism 
for applications (clients, services, etc) to describe dynamic display objects. Using the 
dynamic display objects, application behavior may be altered without having to download 
new code, recompile, or relink the application. 
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The dynamic display objects may be described in XML schemas. These schemas 
may be advertised in spaces. An application (or other services acting on behalf of the 
application) may then access the schemas from the service advertisements to display data 
based upon formatting, data type, and other information stored in the schemas. 

Figures 32A and 32B illustrate examples of using schemas of dynamic display 
objects according to one embodiment. In Figure 32 A, application 1320 (may be a client, 
a service, or other application) has been implemented with display schema advertisement 
1324 stored in space 1326. Display schemas may be provided for displaying the same 
results in different formats, for extracting portions of the results for display, and for 
displaying the results on different display devices. 

In one embodiment, one or more display schema advertisements may be stored in 
one or more spaces in a distributed computing environment. As copies of an application 
are invoked on one or more devices, each copy of the application may run a search for 
services to discover advertisements for the display schemas used by the applications. 
Thus, a central, persistent store of the display information may be kept for multiple 
instances of the application or for other applications. The display information may be 
modified in the central location without requiring the recompilation and/or reinstallation 
of the applications. 

In Figure 32B, client 1328 may locate a service advertisement for service 1330 on 
a space. When invoking service 1330, client 1328 may pass a location of display schema 
advertisement 1324 on space 1326 to service 1330. When service 1330 is ready to 
provide results to client 1328, it may display the results on display 1322 (which may be 
coupled to the device on which client 1328 is running) using the display information from 
the display schema provided by display schema advertisement 1324. To change the way 
the results are displayed, the XML messages in the display schema advertisement 1324 
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may be modified, or a different display schema may be selected, without requiring 
changes at the client 1328 or service 1330. Service 1330 may be a display service. 

String Management 

String handling in conventional systems is generally not very efficient, especially 
for variable sized strings, and may be wasteful of memory space, e.g. as the string is 
copied and/or moved in memory. This inefficiency in string handling may be particularly 
problematic in small memory footprint systems such as embedded systems. The amount 
of memory, particularly stack space and space for dynamic allocation, may be limited in 
small footprint systems. Thus, a more efficient method of handling strings in programs 
executing within small footprint systems such as embedded systems is desirable. 

Figure 33A illustrates a typical string representation in the C progranmiing 
language. In C, a string may be represented by a character pointer 1450 (stringl) 
containing a memory location (address) of the first character of a string 1452. Other 
characters follow the first character in the string 1452, and are typically stored in 
consecutive addressable byte locations in memory. Characters in C strings are typically 
8-bit. The characters in C strings may be any ASCII character. A C string must be 
terminated by a NULL character. NULL is platform defined as one of the 256 possible 8- 
bit values, but is typically the binary value ObOOOOOOOO. The string 1452 occupies 13 
bytes (12 string characters plus the terminating character). 

An example of a string operation in C is the strlen() function, typically provided 
with standard C library implementations. The strlen() function takes a string pointer as 
input and returns the length (in bytes) of the string, not including the terminating 
character. For example, passing the character pointer 1450 to the strlen() function would 
return the length 12. The strlen() function may be implemented by "walking" the string 
until the terminating character is located, counting each character. 
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String copying in C is typically handled by a strcpyO or a stmcpyO C library 
functions, which are implemented as: 

char *strcpy(char *dest, const char *src); 

char *stmcpy(char *dest, const char *src, size_t n); 
The StrcpyO function copies the string pointed to by the character pointer src (including 
the terminating character) to the string pointed to by character pointer dest . The strings 
may not overlap, and the destination string dest must be large enough to receive the copy. 

The StmcpyO function is similar, except that not more than n bytes of src are 
copied. Thus, if there is no terminating character among the first n bytes of src, the result 
will not be terminated. If desired, an instruction may be placed in the code following a 
StmcpyO to add a termination character to the end of the dest string. In the case where 
the length of src is less than that of n, the remainder of dest will be padded with nulls. 
The StrcpyO and stmcpyO functions retum a pointer to the destination string dest . 

Figure 33B illustrates an example of the results of the stmcpyO function on string 
1452, when stmcpyO is called with the following parameters: 

stmcpy(string2, stringl+3, 5); 

where string2 is character pointer 1454 pointing to the first byte after the terminating 
character of string 1452, stringl+3 is character pointer 1450 incremented by 3 bytes, and 
5 is the number of characters (bytes) to be copied from the source location stringl+3 to 
string2. After copying, the next character after the five characters copied from string 1 
may be set to the terminating character (the character may have been initialized to the 
terminating character prior to the copy). Thus, the two strings now occupy (13 + 6) = 19 
bytes of memory. If the strcpyO function was applied with character pointer 1450 as the 
source string, the original string 1452 and the resultant new string would occupy (13*2) 
= 26 bytes. 



Atty. Dkt, No.: 5181-66100 



149 



Conley Rose & Tayon. P.C. 



Figure 33C illustrates an efficient method for representing and managing strings 
in general, and in small footprint systems such as embedded systems in particular. String 
1452 is stored in memory as 12 bytes (no terminating character is required). String 
structure 1460 includes pointers (Address(A) and Address(L)) to the first and last 
characters of string 1452. Using this string structure, the string does not have to be 
"walked" to determine the length. The string's length may be efficiently computed by 
subtracting the pointer to the first character from the pointer to the last character. 

Operations such as string copy operations strcpyO and stmcpyO may also be 
handled more efficiently. With string structures such as those illustrated in Figure 33C, a 
new string structure 1462 may be created, and the first and last character pointers may be 
initialized to point to the respective characters in string 1452. Thus, a portion or all the 
string 1452 does not have to be copied to new storage for the string. As strings can be 
hundreds or even thousands of characters long, the memory saved using the string 
structures and string methods implemented to take advantage of them may be 
considerable. This method of handling copies of portions or all of a string may be called 
"substring management," as it deals with the efficient handling of portions (substrings) of 
strings. 

Other string functions from the standard C string library may be replaced with 
string functions taking advantage of the string structure as illustrated in Figure 33C. 
Examples of other C string functions include, but are not limited to; strstr(), strcat(), and 
sprintf(). 

The string handling structures and methods as described in Figure 33C may be 
used, along with the hierarchical structure of XML documents, to provide more efficient 
handling of XML text (such as XML messages) in systems with small memory footprints 
such as embedded systems. The following is a simple example of an XML schema 
defining a purchase order; 

<!DOCTYPE purchase.order SYSTEM "po.dtd"> 
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<purchase.order> 
<date>22 May 2000</date> 
<billing.address> 
<name>John Smith</name> 
<street>123 Main</street> 
<city>Anywhere</city> 
<state>MA</state> 
<zip>12345-6789</zip> 
</billing.address> 
<items> 
<item> 
<quantity>3</quantity> 
<product.number>248</product.number> 
<description>Decorative Widget, Red, Large</description> 
<unitcost>19.95</unitcost> 
</item> 
<item> 
<quantity> 1 </quanti ty> 
<product.number>1632</product.number> 
<description>Battery, AA, 4-pack</description> 
<unitcost>4.95</unitcost> 
</item> 
</items> 

</purchase.order> 

The hierarchical structure of XML documents may allow them to be processed in 
a recursive fashion with successively smaller portions of the document processed at each 
level of recursion. References to various portions are recorded and processed recursively. 
String structures as described in regard to Figure 33C may be used to record the various 
portions. In this manner, the content of specific XML tags (one line in the above 
example), in one embodiment the smallest unit of the XML document processed 
recursively, may be determined efficiently. Documents with repeated tags in the same 
scope may also be handled efficiently, as tags within a given scope may be enumerated 
and processed efficiently. 



A recursive method for processing an XML document using string structures 
similar to those described in Figure 33C may accept a string structure representing the 
entire XML document string and pointing to the first byte and the last byte in the 
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document string. The method may then locate the next subsection of the document and 
pass a string structure representing the substring of the entire document string containing 
the subsection to a processing function for the subsection type. The subsection itself may 
be broken into another level of subsections represented by string structures passed to 
processing functions for the subsection type. The method may continue in the recursive 
processing of the XML document subsections until the entire document has been 
processed. 

Using the string structures with the recursive processing allows the processing to 
be done without creating copies of the subsections for processing. Copying of 
subsections may be particularly costly in recursive processing, because as the recursion 
goes deeper, more and more copies of the same data are made. Using the string 
structures, only the string structure containing the pointers to the first and last bytes in the 
subsection needs to be created and passed down to the next level. Other operations, such 
as determining the length of a subsection, may be performed efficiently using the address 
information stored in the string structures. Also, by using the string structures, 
terminating characters such as those used to terminate C strings are not necessary, 
conserving memory in small footprint devices such as embedded devices. 

XML representation of Objects 

As previously mentioned, Jini RMI may not be practical for some clients, such as 
thin clients with minimal memory footprints and minimal bandwidth. The serialization 
associated with the Jini RMI is slow, big, requires the JVM reflection API, and is a Java 
specific object representation. Java deserialization is also slow, big and requires a 
serialized-object parser. Even Java based thin clients may not be able to accept huge Java 
objects (along with needed classes) being returned (necessarily) across the network to the 
client, as required in Jini. 
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A more scalable distributed computing mechanism may be provided by 
embodiments of a distributed computing environment. A distributed computing 
environment may include an API layer for facilitating distributed computing. The API 
layer provides send message and receive message capabilities between clients and 
services. This messaging API may provide an interface for simple messages in a 
representation data or meta-data format, such as in the extensible Mark-up Language 
(XML). Note that while embodiments are described herein employing XML, other meta- 
data type languages or formats may be used in alternate embodiments. In some 
embodiments, the API layer may also provide an interface for messages to communicate 
between objects or to pass objects, such as Java objects. Objects accessible through API 
layer 102 are represented by a representation data format, such as XML. Thus, an XML 
representation of an object may be manipulated, as opposed to the object itself. 

The API layer may sit on top of a messaging layer. The messaging layer may be 
based on a representation data format, such as XML. In one embodiment, XML messages 
are generated by the messaging layer according to calls to the API layer. The messaging 
layer may provide defined static messages that may be sent between clients and services. 
Messaging layer may also provide for dynamically generated messages. In one 
embodiment, an object, such as a Java object, may be dynamically converted (compiled) 
into an XML representation. The object may include code and/or data portions. The 
object's code and/or data portions may be compiled into code and data segments 
identified by XML tags in the XML representation. The messaging layer may then send 
the XML object representation as a message. Conversely, the messaging layer may 
receive an XML representation of an object. The object may then be reconstituted 
(decompiled) from that message. The reconstitution may examine the XML 
representation for tags identifying code and/or data segments of the XML representation, 
and use information stored in the tags to identify and decompile the code and/or data 
portions of the object. 
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Creating and sending an XML representation of an Object 

Figure 34 illustrates a process of moving Java objects between a client 1500 and a 
service 1502 according to one embodiment. Service 1502 may be any service supported 
in the distributed computing environment, including space services. Client 1500 employs 
a gate 1504, which may have been created using an XML schema received from a service 
advertisement for service 1502, to communicate with a corresponding gate 1506 for 
service 1502. At some point, client 1500 may need to send Java object 1510 to service 
1502. Java object 1510 may reference other objects, which may in turn reference other 
objects, and so on. Java object 1510 and its referenced objects, the objects they in turn 
reference, and so on, may be referred to as an object graph. 

Java object 1510 may be passed to a Java object compilation process 1512 to be 
compiled to produce an XML representation of the object graph. The XML 
representation of the object graph may be passed as an XML data stream 1514 to gate 
1504. The XML data stream 1514 may include an XML representation of all the objects 
in the object graph. In one embodiment, the objects in the object graph may be stored 
recursively in the XML data stream 15 14. 

Gate 1504 may then package the XML data stream 1514 in a message 1516 and 
send the message 1516 to gate 1506 of service 1502. Gate 1506 may extract the XML 
data stream 1514 from XML message 1516 and send the XML data stream 1514 to an 
XML data stream decompilation process 1518 to be decompiled to produce the object(s) 
comprising the object graph, including Java object 1510. In one embodiment, the objects 
in the object graph may be stored recursively in the XML data stream 1514, and thus a 
recursive decompilation process may be used. 

When service 1502 needs to send a Java object to client 1500, a substantially 
similar process may be used. Java object 1520 may be passed to a Java object compilation 
process 1512 to be compiled to produce an XML representation of the object graph. The 
XML representation of the object graph may be passed as an XML data stream 1522 to 
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gate 1506. Gate 1506 may then package the XML data stream 1522 in a message 1524 
and send the message 1524 to gate 1504 of cHent 1500. Gate 1504 may extract the XML 
data stream 1522 from XML message 1524 and send the XML data stream 1522 to an 
XML data stream decompilation process 1518 to be decompiled to produce the object(s) 
comprising the object graph, including Java object 1520. 

In another embodiment, the gates may be responsible for the compilation and 
decompilation of Java objects. In this embodiment, Java object 1510 may be passed to 
gate 1504. Gate 1504 may then pass object 1510 to a Java object compilation process 
1512 to be compiled to produce an XML representation of the object graph in an XML 
data stream 1514. Gate 1504 may then package the XML data stream 1514 in a message 
1516 and send the message 1516 to gate 1506 of service 1502. Gate 1506 may extract the 
XML data stream 1514 from XML message 1516 and send the XML data stream 1514 to 
an XML data stream decompilation process 1518 to be decompiled to produce the 
object(s) comprising the object graph, including Java object 1510. The process of 
sending a Java object from service 1502 to client 1500 may be substantially similar to the 
process of sending an object from the client to the service. 

In one embodiment, object compilation process 1512 and object decompilation 
process 1518 may both exist on the client 1500 and the service 1502, and may be 
programmed to perform compilation and decompilation substantially similarly on the two 
devices, thus ensuring the object(s) output on one end are substantially identical to the 
object(s) input on the other end. In one embodiment, XML schemas including 
descriptions of Java objects may be used on both the client and/or the service in the 
compilation and decompilation processes. In one embodiment, XML schema(s) to be 
used in the compilation and decompilation of Java objects may be passed by the service 
to the client in the service advertisement. 

XML provides a language- and platform-independent object representation 
format. Thus, the process as illustrated in Figure 34 where an object is compiled into an 



Atty. Dkt. No.: 5181-66100 



155 



Conley Rose & Tayon, P.C. 



XML representation of the object and decompiled to reproduce the object may not be 
limited to moving Java objects, but in some embodiments may be applied to moving 
objects of other types between entities in a network. 

Figure 46 illustrates a mechanism for sending objects from services to clients 
using XML representations of the objects. In step 2200, a client may request an object 
from a service. In one embodiment, the object may be a Java object. In one embodiment, 
the client may send a message (e.g. an XML message) to the service requesting the object. 
In step 2202, the service, after receiving the request, may provide the object to a 
compilation process. In one embodiment, the compilation process may be integrated in 
the virtual machine within which the service is executing. In one embodiment, the virtual 
machine may be a Java Virtual Machine (JVM). In one embodiment, the compilation 
process may be provided as an extension to the JVM. In step 2204, the compilation 
process generates a data representation language representation of the object. In one 
embodiment, the data representation language is XML. The representation of the object 
may include a name or identifier for the object and one or more instance variables for the 
object. An instance variable, in object-oriented programming, is one of the variables of a 
class template that may have a different value for each object of that class. In step 2206, 
the service may send the data representation language representation of the object to the 
client. In one embodiment, the representation may be packaged in a message. In one 
embodiment, the message is in the data representation language. Message gates, as 
described elsewhere herein, may be used for message passing between the client and 
service. 

In step 2208, the client receives the data representation language representation of 
the object and provides the representation to a decompilation process. In one 
embodiment, the decompilation process may be integrated in the virtual machine within 
which the client is executing. In one embodiment, the virtual machine may be a Java 
Virtual Machine (JVM). In one embodiment, the decompilation process may be provided 
as an extension to the JVM. In step 2210, the decompilation may generate a copy of the 
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object from the data representation language representation of the object. The object may 
then be provided to the client. 

JVM compilation/decompilation API 

5 

Figures 35a and 35b are data flow diagrams illustrating embodiments where a 
virtual machine (e.g. JVM) includes extensions for compiling objects (e.g. Java Objects) 
into XML representations of the objects, and for decompiling XML representations of 
(Java) objects into (Java) objects. The JVM may supply an Applications Programming 
10 Interface (API) to the compilation/decompilation extensions. The client 1500 and service 
1502 may be executing within JVMs. The JVMs may be on the same device or on 
different devices. 

ff^ In both Figure 35a and Figure 35b, the JVM XML compiler/decompiler API 1530 

yj 15 may accept a Java object 1510 as input, and output an XML representation of the object 

1510 and all its referenced objects (the object graph of object 1510) in an XML data 



^ stream 1514. In addition, the JVM XML compiler/decompiler API 1530 may accept an 



2 



i : 



XML data stream 1522, which includes an XML representation of object 1520 and all its 
referenced objects (the object graph of object 1520), and output Java object 1520 (and all 
20 the objects in its object graph). 

Figure 35a illustrates one embodiment where, when sending Java object 1510, the 
JVM XML compiler/decompiler API 1530 is called by the client. The client 1510 passes 
Java object 1510 to the API 1530, which compiles the object to produce its XML 
25 representation, stores the XML representation in XML data stream 1514, and outputs 
XML data stream 1514. XML data stream 1514 may then be passed to gate 1504 by the 
client. Gate 1504 may then package the XML data stream 1514 in an XML message 
1516 and send message 1516 to service 1502. 

30 Upon receiving XML message 1524 from service 1502, gate 1522 may extract 

XML data stream 1522 from message 1524 and pass data stream 1522 to client 1500. 
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Client 1500 may then call the JVM XML compiler/decompiler API 1530, passing API 
1530 the XML data stream 1522. The API 1530 may then decompile the XML data 
stream 1522 to produce Java object 1520 and other objects in its object graph, returning 
the objects to client 1500. 

Figure 35b illustrates another embodiment where, when sending Java object 1510, 
the JVM XML compiler/decompiler API 1530 is called by the gate. The client 1510 
passes Java object 1510 to gate 1504. Gate 1504 then passes object 1510 to API 1530, 
which compiles the object to produce its XML representation, stores the XML 
representation in XML data stream 1514, and outputs XML data stream 1514. Gate 1504 
may then package the XML data stream 1514 in an XML message 1516 and send 
message 1516 to service 1502. 

Upon receiving XML message 1524 from service 1502, gate 1522 may extract 
XML data stream 1522 from message 1524 and pass data stream 1522 to the JVM XML 
compiler/decompiler API 1530. The API 1530 may then decompile the XML data stream 
1522 to produce Java object 1520 and other objects in its object graph. The gate may 
then send Java object 1520 and the other objects to client 1500. 

In one embodiment, the JVM XML compiler and decompiler may be 
implemented as integrated functions of the JVM. In another embodiment, the XML 
compiler and decompiler may be embodied in API method invocations in standard 
extensions to the JVM; thus, the core JVM does not have to be modified. The JVM may 
supply the JVM XML compiler/decompiler API 1530 to processes (clients and/or 
services) executing within the JVM to allow the processes to access the Java object 
compilation/decompilation functionality provided by the JVM. In one embodiment, for a 
process to utilize the object compilation/decompilation, the JVM within which the 
process is executing must have the JVM XML compiler/decompiler functionality and API 
1530. 
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Methods using reflection and serialization to transform and send objects are 
typically implemented in applications separate from the JVM. The application must 
repeatedly access the JVM to pick apart an object one field at a time as the transitive 
closure of the object is dynamically analyzed. This tends to be a slow and cumbersome 
process, while also requiring large amounts of application and JVM code. 

Implementing the Java object compilation/decompilation functionality within the 
JVM is advantageous because the JVM already understands the concept of, and contents 
of, an object graph. Thus, the compilation/decompilation functions may leverage the 
knowledge (and reuse code) of the JVM in parsing the object graph to produce the XML 
representation, and in parsing the XML representation to produce the object graph. Thus, 
the compilation/decompilation functions may not have to duplicate functionality that is 
provided by the JVM, as do object sending methods using reflection and serialization. 
This may allow the code footprint of the compilation/decompilation functions to be 
smaller than that of object sending methods using reflection and serialization. Also, an 
object may be complied or decompiled by a single call to the JVM XML 
compiler/decompiler API. 

In addition, integrating the compilation/decompilation of objects with the JVM 
may allow the compilation and decompilation of objects to be performed faster than 
methods using reflection and serialization because, in the object traversal model 
implemented with reflection and serialization, the code outside the JVM does not know 
the structure or graph of the Java object, and thus must traverse the object graph, pulling 
it apart, and ultimately must repeatedly call upon the JVM to do the compilation (and the 
reverse process for decompilation). This process may be slowed by the necessity of 
making repeated calls to the JVM, outside the code. Having the compilation and 
decompilation functionality integrated with the JVM, as described herein, avoids having 
to make repeated calls from code outside the JVM to the JVM. In one embodiment, an 
object may be complied or decompiled by a single call to the JVM XML 
compiler/decompiler API. 
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In one embodiment, the compilation/decompilation functionality may be 
implemented as a service in the distributed computing environment. The service may 
publish a service advertisement in a space. A process in the distributed computing 
environment may use a search or discovery service to locate the 
compilation/decompilation service. The process (a client of the service) may then use the 
service by passing Java objects to be compiled into XML representations and/or XML 
representations to be decompiled into Java objects to the service. 

Java objects may include code (the object's methods) and data. An object's code 
may be non-transient; the code does not change once the object is created. An object's 
data, however, may be transient. Two objects created from the same Java class may 
include identical code, but the data in the two objects may be different. In one 
embodiment, the compilation function may compile a Java object's data into an XML 
representation of the object, but may not include the object's actual code in the XML 
representation. In one embodiment, information about the object may be included in the 
compiled XML representation to indicate to the receiver how to recreate the code for the 
object. The XML representation may then be stored in an XML data stream and sent (e.g. 
in a message) to a receiving process (client or service). The receiving process may then 
pass the XML data stream to the decompilation function. The decompilation function 
may then decompile the XML data stream to produce the Java object including its data. 
In one embodiment, the code for the object may be reproduced by the decompilation 
function using information about the object included in the XML representation, as the 
code for an object may be statically defined and the JVM receiving the object may be able 
to reproduce the code (if necessary) using its knowledge of the object. 

In one embodiment, the XML representation of an object produced by the 
compilation function may include the Java object's data and information about the Java 
object. The information may include class information for the Java object. An object 
signature may be included in the information and may be used to identify the object's 
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class, etc. The decompilation function may recreate the code for the Java object using the 
information about the Java object and may decompile the data from the XML data stream 
into the Java object. Thus, a complete object including its code and data may be 
reproduced on the JVM executing the receiving client or service from the decompiled 
data and the information describing the object. In one embodiment, the information 
describing the object may be stored in one or more XML tags. In one embodiment, the 
client or service receiving the XML data stream may include an XML schema that 
describes the object, and the XML schema may be used to reconstruct the Java object 
from the decompiled data and from the information about the Java object. The 
decompilation process may proceed recursively through the object graph, reconstructing 
the objects referenced by the object by decompiling the referenced objects' data from the 
XML data stream and recreating the referenced objects' code from information about the 
referenced objects in the XML data stream. 

In one embodiment, the XML representation of the object produced by the 
compilation function may include the object's data and information that identifies the 
code of an object. In one embodiment, the information identifying the code of the object 
may be stored in one or more XML tags in the XML data stream. When received, the 
decompilation function may recreate the code for the Java object using the information 
about the code from the XML data stream and decompile the data for the object from the 
XML data stream. Thus, a complete object including its code and data may be 
reproduced on the JVM executing the receiving client or service from the decompiled 
data and the information describing the code of the object. 

Several scenarios of using XML representations of objects to transfer objects 
between entities (typically clients and services) in a distributed computing environment 
are included for clarification. These scenarios are exemplary and are not intended to be 
limiting. 
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In a first scenario, a service may use the XML compiler/decompiler to compile a 
Java object into an XML representation of the object and send the XML representation to 
a cHent. The client may the use the XML compiler/decompiler to decompile the XML 
representation and perform operations on the data within the object, and later may use the 
XML compiler/decompiler to compile the object into an XML representation of the 
object and return the XML representation of the object to the service. 

In a second scenario, a service may use the XML compiler/decompiler to compile 
a Java object into an XML representation of the object and send the XML representation 
to a client. The client may then send the XML representation to another service, which 
may use the XML compiler/decompiler to decompile the XML representation to 
reproduce the object, perform operations on the object at the request of the client 
(possibly modifying the data), use the XML compiler/decompiler to recompile the 
modified object into its XML representation, and send the XML representation of the 
object to the client. 

In a third scenario, a service may use the XML compiler/decompiler to compile a 
Java object into an XML representation of the object and send the XML representation to 
an object repository or store space. The service may then send a message to a client 
informing the client of the location of the XML representation. The message may include 
a Universal Resource Identifier (URI) for the XML representation. The client may then 
retrieve the XML representation of the object from the store space, and may use the XML 
compiler/decompiler to decompile the representation to reproduce the object. 
Alternatively, the client may send the location of the XML representation of the object to 
another service, along with a request for operations to be performed on the object. The 
other service may then retrieve the XML representation from the store space, use the 
XML compiler/decompiler to decompile the XML representation to reproduce the object, 
and perform the requested operations on the object. 
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In a fourth scenario, a process (could be a client or service) may locate an object 
repository or store space in the distributed computing environment by searching for and 
finding a service advertisement for the store space. The process may, during execution, 
create or obtain a plurality of Java objects. The process may use the XML 
compiler/decompiler to compile one or more of the objects into XML representations of 
the objects, and may send, as a client of the store space service, the XML representations 
of the objects to the store space to be stored for possible later access, or for access by 
other processes. 

Security issues in the Decompilation of XML Representations of Objects 

Spaces, as described herein, may serve as a file system in the distributed 
computing environment. Security may be provided for files in the system in the form of 
access rights. Access rights may be checked each time a file is accessed (opened, read, or 
written to). Thus, a method for providing file access security in the distributed computing 
environment may be desirable. This method may also be applied to the XML 
representations of Java objects that may be stored in spaces and transmitted between 
clients and services in the distributed computing environment. 

In one embodiment, a user of a client on a device in the distributed computing 
environment may be identified and authenticated when first accessing the client. In one 
embodiment, the user may supply a physical identification such as a smart card for 
identification and authorization. In another embodiment, a challenge-response 
mechanism (such as user ID and password) may be used for identification and 
authorization. Yet another embodiment may use electronic identification such as a digital 
signature for identification and authorization. Any other method of identification and 
authorization may be used. 

Once identified and authorized, the user may then perform various operations on 
the client, including accessing one or more services in the distributed computing 
environment. During these operations, as described above, one or more objects may be 
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created (locally) or acquired from elsewhere (e.g. from services or spaces). The objects 
may be modified and may be compiled into XML representations of the objects and 
stored locally by the client or sent to a space service for (transitive or persistent) store. 
Some of the objects may be received from services (store services or other services) in the 
5 form of XML representations of the objects, which may be decompiled by the XML 
compiler/decompiler to recreate the objects on the client. 



In one embodiment, during the decompilation of the XML representation of 
objects, each XML message may be checked to verify that the user has access rights to 
10 the object. If the user does not have the proper access rights, the XML 
compiler/decompiler may not decompile the object for the user. In one embodiment, a 
^ security exception may be thrown by the XML compiler/decompiler. In one embodiment, 

'^M the user may be informed of the access violation. 

: M 

S 15 Access right information, such as the creator and access levels allowed (creator- 

W only access, read only, read/write, delete, copy, etc.) for the object may be embedded in 

I 

3 the XML message(s) containing the XML representation of the object. Access 

authorization may be determined during the identification and authorization of the user. 
^ For example, the object may allow "read only" access for most users, and "read/write" 

□ 20 access for the creator of the object. If the user tries to access an object using read/write 

: ""e 

^ access rights, and the object was not created by the user, the decompilation process may 

detect this as an access violation, and may disallow the access and notify the user. 

In one embodiment, when the user is done using the client, the user may log off or 
25 otherwise signal the user is finished with the client (e.g. remove a smart card). Objects 
created on the client by decompilation may be automatically deleted when the client 
detects that the user is finished. This may prohibit future users from intentionally or 
accidentally accessing the user's objects. In one embodiment, all objects created by 
decompilation may be deleted upon detecting that the user is finished. In another 
30 embodiment, a method may be provided to store at least some of the objects created on 
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the client persistently (e.g. with access rights information), so that the client may later 
access the objects, or provide the objects to other users for access. 

In one embodiment, the user may have a "smart card" or other physical device to 
gain access to the client. The user may insert the smart card into the client device to 
begin the session. When the client is finished, the client may remove the smart card. The 
client may detect the removal of the smart card, and thus detect that the client is finished, 
and may then proceed to delete objects created by decompilation of XML representations. 

Figure 47 illustrates a mechanism for secure object decompilation on a client 
device. In step 2240, a user may access a client device. In one embodiment, the user may 
provide identification to the client. In one embodiment, the user may log on to the client, 
for example, with a user name and password. In one embodiment, the user may provide a 
physical identification method, e.g. a smart card, to the client device to establish the 
user's identity with the device. 

After the user has been authenticated, the client may request one or more objects 
from one or more services during access by the user. In one embodiment, the objects may 
be Java objects. In one embodiment, the client may send messages (e.g. an XML 
messages) to the services requesting the objects. The services, after receiving the 
requests, may send the data representation language representations of the objects to the 
client. In one embodiment, the representations may be packaged in messages. Message 
gates, as described elsewhere herein, may be used for message passing between the client 
and service. 

In step 2242, the client receives the data representation language representations 
of the objects and provides the representations to a decompilation process. In one 
embodiment, the decompilation process may be integrated in the virtual machine within 
which the client is executing. In one embodiment, the virtual machine may be a Java 
Virtual Machine (JVM). The decompilation may generate copies of the objects from the 
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data representation language representations of the objects. In one embodiment, the 
messages may be checked to make sure the client has access privileges to the requested 
objects. The objects may then be provided to the client to be available for use during 
access by the user. 

In step 2244, the user may end access to the client device. For example, the user 
may log off or, if one was used, may remove an identification device such as a smart card 
to signal to the client device that the user is ending access of the client. Upon detecting 
that the client has ended the access, the client device may automatically delete any objects 
that have been decompiled for the user during the access by the user. Deleting the objects 
may insure that the objects are not left on the client device to be accidentally or 
intentionally accessed by subsequent users of the device. 

Alternatively, one or more of the objects may not be deleted when the user 
terminates access. Instead, the objects may be stored (either locally or elsewhere in the 
distributed computing environment) for later access by the user. In one embodiment, 
access information of the client may be stored with the objects to prevent unauthorized 
users from accessing the objects. 

XML-based object repositories 

In the distributed computing environment, processes (services and/or clients) may 
desire transient and/or persistent storage of objects such as XML schemas, service 
advertisements, results generated by services, XML representations of Java objects and/or 
objects implemented in other languages, etc. Existing object storage technologies tend to 
be language and/or operating system specific. These storage systems also tend to be too 
complicated to be used with small footprint systems such as embedded systems. 

JavaSpaces in Jini is an existing object repository mechanism. A JavaSpace may 
be only capable of storing Java objects and may be too large to be implemented in small 
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devices with limited amounts of memory. Each object in a JavaSpace may be serialized 
as previously described, and thus has the same limitations as previously described for the 
reflection and serialization techniques. 

A store mechanism may be provided for the distributed computing environment 
that may be heterogeneous (not language or operating system dependent), that may scale 
from small to large devices, and that may provide transient or persistent storage of 
objects. In one embodiment, the store mechanism in the distributed computing 
environment may be implemented as an Internet Web page or set of pages defined in the 
XML markup language. XML provides a language- and platform-independent object 
representation format enabling Java and non-Java software to store and retrieve language- 
independent objects. Since the store mechanism is on the Web, devices of all types and 
sizes (small to large) may access the store mechanisms. Web browsers may be used to 
view the store mechanism implemented as Web pages. Web search engines may be used 
to search for contents in the store mechanism implemented as Web pages. Internet 
administration mechanisms (existing and future) and XML tools may be used to 
administer the XML-based store mechanisms. 

In one embodiment, the store mechanisms may be used to store objects created, 
represented or encapsulated in XML. Examples of objects that may be stored in the store 
mechanisms may include, but are not limited to: XML schemas, XML representations of 
objects (for example, Java objects compiled into XML representations as described 
above), service advertisements, and service results (data) encapsulated in XML. In one 
embodiment, to prevent unauthorized access of an XML object, an authorization 
credential such as a digital signature or certificate may be included with the XML object, 
and a client wishing to access the XML object may be required to have the proper 
authorization credential to access the XML object. In one embodiment, the store 
mechanism may be a space as described in the Spaces section herein. 
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Store mechanisms may be services in the distributed computing environment. A 
store mechanism implemented as a service may be referred to as a "store service". A 
store service may pubHsh an advertisement in a space. The space itself is an example of a 
store service. Some store services may be transient. For example, a space service that 
stores service advertisements may be a transient store. Other store services may be 
persistent. For example, a store service that stores results from services may be a 
persistent store. 

Figure 36 illustrates a client 1604 and a service A 1606 accessing store 
mechanisms 1600 and 1602 in the distributed computing environment according to one 
embodiment. This illustration is intended to be exemplary and is not intended to be 
limiting to the scope of this invention. In one embodiment, store mechanisms 1600 and 
1602 may each be an Internet Web page or set of Web pages defined in XML and 
accessible by a Web browser and other Internet tools. Store mechanism 1600 is a 
transient store capable of storing objects implemented using XML. Store mechanism 
1602 is a persistent store also capable of storing objects implemented using XML. 
Service A 1606 may publish an XML service advertisement 1608 in transient store 1600. 
Persistent store may also publish an XML service advertisement in transient store 1600 
(or on another transient store in the distributed computing environment). At some point, 
client 1604 may require functionality provided by Service A 1606. Client 1604 may use a 
discovery and/or lookup service to locate service advertisement 1608. Client 1604 may 
then construct a message gate, as described herein, and begin conrmiunications with 
Service A 1606. Client 1604 may send one or more XML request messages to Service A 
1606. Service A 1606 may perform one or more functions in response to the one or more 
request messages. One or more of the functions performed by Service A 1606 may 
produce results to be provided to client 1604. 

For transient results 1610, Service A 1606 may encapsulate the results in an XML 
advertisement 1612 and publish the advertisement 1612 in transient store 1600 (or on 
another transient store in the distributed computing environment). Service A 1606 may 
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then notify client 1604 that the results 1610 are stored in advertisement 1612 on transient 
store 1600, or client 1604 may be notified by other mechanisms as described herein. 
Client 1604 may then retrieve transient results 1610 from advertisement 1612. The 
advertisement 1612 may include an XML schema describing the formatting, contents, 
5 type, etc. of the transient results 1610. The results may be encapsulated in XML. For 
example, XML tags may be used to describe portions of the data: 



<XML tag 1 > <data 1 > 
<XMLtag2> <data2> 

10 



n 



O 



^ For persistent results 1618, Service A 1606 may use a service or other mechanism 

S as described herein to locate XML service advertisement 1616 for persistent store 1602, 

01 

and thus locate persistent store 1602 for storing persistent results. Alternatively, client 
^ 15 1604 may have previously located persistent store 1602 by locating its service 

advertisement 1616, and then may send a Universal Resource Identifier (URI) for a 
storage location for persistent results 1618 to Service A in an XML message. In one 
embodiment, persistent results 1618 may be stored in an Internet Web page or set of Web 
pages defined in XML and accessible by a Web browser. Service A 1606 may then store 
20 persistent results 1618 in persistent store 1602. Service A 1606 may then publish an 
XML advertisement 1616 for the persistent results 1618 in transient store 1600 (or on 
another transient store in the distributed computing environment) and return the location 
of the advertisement 1616 to client 1604. The advertisement 1616 may include an XML 
schema describing the formatting, contents, type, etc. of the persistent results 1618. The 
25 results may be encapsulated in XML as previously described. The advertisement may 
also include the URI of the persistent results 1618. The client 1604 may then retrieve the 
advertisement 1616 and use it to locate and retrieve persistent results 1618. Alternatively, 
Service A 1606 may not publish an advertisement for persistent results 1618, but instead 
may return a URI for the persistent results 1618 to client 1604 so client 1604 may access 
30 the results without looking up an advertisement. Note in some embodiments, the various 
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advertisements shown in transient store 1600 may each be stored in different transient 
stores or spaces. 

Thus, store mechanisms may be implemented as XML-based Internet Web pages 
in the distributed computing environment. These store mechanisms may be implemented 
on a variety of devices in the environment, and may provide service advertisements to 
allow clients (which may be other services) to locate and use the store mechanisms. 
Existing and future Web and XML tools may be used to manage the store mechanisms. 
The store mechanisms may store objects of various types implemented or encapsulated in 
XML. Clients on devices of substantially any size, from small footprint devices to 
supercomputers, may access the store mechanisms to store and retrieve the various 
objects on the Internet. The clients may be Java or non-Java applications, as XML 
provides a language-independent storage format. The transient or persistent object 
repositories may provide for a file system in the distributed computing environment and 
may include access checks and other security mechanism as described herein. 

Dynamically Converting a Java Object into an XML Document 

In one embodiment, the distributed computing environment may provide a 
mechanism to convert and represent an object class instance into an XML document. In 
order to send representation of a class instance to another service, the object may be 
converted and represented as an XML document. In one embodiment, when receiving an 
XML document, a program may instantiate a class instance corresponding to the object 
represented by the document. In one embodiment, the objects may be Java objects, and 
the program may be a Java program. 

In one embodiment, an intermediary format may be used to represent an XML 
document and may be dynamically processed to generate a class instance that represents 
the XML document. The class may define a set of instance variables and "set and get" 
methods to access the instance variables. A corresponding XML document may be 
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defined as a set of tags, with one tag for each instance variable. When the document is 
parsed, a hashable representation may be constructed where the hash key may include the 
instance variable name and the value may include the instance variable value. If there are 
multiple occurrences of a complex instance variable, an enumeration value may be stored 
in a hash table. In one embodiment, the process may be limited to only one level of 
complex types for the instance variables, and the elements may be homogeneous. 

In one embodiment, a protected instance variable may be added to the class 
definition that may include the name of the corresponding class. The XML document 
representation may use the class name as the document type. Having the class name 
embedded in the document may allow dynamic instantiation of the right class instance 
when the object is reconstructed. 

In one embodiment, upon receiving a document, a class instance generator method 
may be used to extract the class type and to parse the document to generate the 
intermediary hash table representation. The generator method may instantiate a new class 
instance and may use the set methods to initialize the instance object from the hash table 
values. In one embodiment, since the class type is defined and the hash table is generic, 
this process may be performed for any class that matches the above class definition. 

In one embodiment, the reverse process may also be performed where a class 
instance may be processed into the intermediary hash table representation and a generator 
method may be used to produce an XML document from the hash table representation. 
This process may also be made generic so that it may be performed for any XML 
document that matches the above specification. 

This method is not intended to be limited to Java Class objects, and may be 
applied to other computer-based objects, including class object instances of other 
progranmiing languages. In addition, the method is not intended to be limited to XML 
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representations of object instances; other representation formats including other data 
representation languages (such as HTML) may be substituted for XML. 

XML-Based Process Migration 

The distributed computing environment may enable the distribution and 
management of distributed applications. For example, the distributed computing 
environment may include mobile clients that are dockable with stations that provide 
monitors, printers, keyboards, and various other input/output devices that are typically not 
provided on mobile devices such as PDAs, cell phones, etc. These mobile clients may 
run one or more applications, and may migrate from one station to another in the 
distributed computing environment. Thus, one embodiment of the distributed computing 
environment may provide a method for migrating an executing application (process) with 
its entire current state from a mobile client on one node to the same mobile client or 
another mobile client at another node within the distributed computing environment. 

In one embodiment, an XML representation of the state of a process executing on 
a client or service may be created. In one embodiment, the XML representation of the 
state of the process may include a computation state of the device and/or virtual machine 
on which the process is executing, wherein the computation state of the device and/or 
virtual machine comprises information about the execution state of the process on the 
device and/or virtual machine. A process state may include, but is not Hmited to: 
threads, all objects referenced by the threads, transient variables created during the 
execution of the process, objects and their data, etc. In one embodiment, data describing 
one or more leases representing grants of access to external services, obtained from 
spaces by the process, wherein the one or more external services are external to the device 
and/or virtual machine on which the process is executing, may also be represented in 
XML and stored with the process state. Leases are described in more detail in the Leases 
section of this document. 
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Using XML and the messaging system as described herein, an XML 
representation of the state of a process may be moved from node to node within the 
distributed computing environment, e.g. from node to node on the Internet. The XML 
5 representation of the state of a process may also be stored as an XML object in an XML- 
based store mechanism as described above, and later retrieved from the store mechanism 
to resume the process execution on the same node or on a different node in the distributed 
computing environment. In one embodiment, the XML object compilation/decompilation 
process as described herein may be used in creating (compiling) an XML representation 
10 of the state of a process and in regenerating the state of the process by decompiling the 
XML representation of the state of the process. 

Using this mechanism, an XML representation of the state of a process may be 
stored in an XML-based store mechanism, such as a space, from an initial node. 
Subsequently, another node may locate the stored state of the process, download the state 
of the process, and resume the process from the downloaded stored state at the point at 
which it was executing when the state was stored. Since the process state is stored in an 
XML format, the tools and search facilities described herein to store, locate and retrieve 
XML objects in XML-based store mechanisms may be used to enable the migration of the 
process. An advertisement of the stored XML representation of the state of the process 
may be published to allow a client resuming the process execution on the same node or 
another node to locate and access the stored sate. 
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The XML representation of the state of a process may be stored to an XML-based 
25 persistent store mechanism, and thus may provide a persistent snapshot of the process. 
This may be used as a method to resume process execution on a node after the 
interruption of the process on the node, for example, due to the intentional or 
unintentional shutdown of the node. An advertisement of the stored state of the process 
may be published to allow clients to locate the stored state in the distributed computing 
30 environment. In one embodiment, to prevent unauthorized access of an XML 
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representation of the stored state of a process, an authorization credential such as a digital 
signature or certificate may be included with the stored state, and a client wishing to 
resume a process from the stored state may be required to have the proper authorization 
credential to access the stored state. 

Figure 37 illustrates process migration using an XML representation of the state 
of a process according to one embodiment. Process A 1636a may be executing on node 
1630. Process A 1636a may be a client or service. At some point during the execution of 
Process A 1636a, the state of execution of Process A 1636a may be captured and stored in 
an XML-encapsulated state of Process A 1638. The execution of Process A 1636a on 
node 1630 may then be stopped. Later, node 1632 may locate the XML-encapsulated 
state of Process A 1638 and use it to resume Process A 1636b on the node 1632. 
Resuming Process A may include using the stored state 1638 to resume thread execution, 
recalculate transient variables, re-establish leased resources, and perform any other 
functions necessary to resume execution as recorded in the stored XML state of the 
process 1638. 

The following is an example of using XML-based process migration in the 
distributed computing environment, and is not intended to be limiting. A mobile client 
device may be connected to node 1630 and executing Process A 1636a. The user of the 
mobile client device may desire to stop execution of Process A 1636a on node 1630, and 
to resume execution at a later time at another (or the same) node. In one embodiment, the 
user may be prompted with a query to determine if the user wishes to store the state of 
Process A 1636a and resume execution later. If the user replies in the affirmative, the 
XML-encapsulated state of the process may be captured and stored in persistent store 
1634. Later, the user may connect the mobile computing device at node 1632. In one 
embodiment, the user may then execute process 1636b and select a "Resume from Stored 
State" option. The node 1632 may then search for and locate the XML-encapsulated state 
of Process A 1638, download it, and use it to resume Process A 1636b. Alternatively, the 
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process may itself know that it was "suspended" on another node, and may resume from 
the stored state without user input. 

Figure 48 illustrates a mechanism for migrating processes using data 
representation language (such as XML) representations of the processes in a distributed 
computing environment. In step 2260, a process is executing within a first device. In 
step 2262, a current computation state of the process is converted into a data 
representation language representation of the current computation state, wherein the 
computation state of the process comprises information about the execution state of the 
process within the first device. This information may include, but is not limited to, 
information about one or more threads of the process, information about one or more 
leases to services held by the process, and information about one or more objects of the 
process (such as objects held by the threads), wherein an object is an instance of a class in 
a computer prograrruning language (such as the Java programming language). 

In step 2264, the data representation language representation of the current 
computation state of the process may be stored. In one embodiment, the representation 
may be stored locally. In one embodiment, the data representation language 
representation of the current computation state of the process may be stored to a space 
using a space service. In one embodiment, the data representation language 
representation of the current computation state of the process may be sent to the space 
service in one or more messages. 

In step 2266, a second device may access the stored data representation language 
representation of the current computation state of the process. In one embodiment, an 
advertisement may be provided for the stored data representation language representation, 
and the second device may receive or access the advertisement and use information in the 
advertisement to locate and access the stored data representation language representation. 
In step 2268, the process may be reconstituted at the current computation state within the 
second device from the accessed data representation language representation of the 
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current computation state of the process. The process may then resume execution within 
the second device from the current computation state. 



Alternatively, the process execution may be ended on the first device subsequent 
5 to step 2264. The first device may then subsequently access the stored data 
representation language representation of the current computation state of the process. 
The process may then be reconstituted at the current computation state within the first 
device from the data representation language representation of the current computation 
state of the process and execution of the process may be resumed within the first device 
10 from the current computation state. 



In another alternative, the data representation language representation of the 
current computation state of the process generated at step 2262 may be sent directly to the 
second device (e.g. in one or more data representation language messages through 
15 message gates). The process may then be reconstituted at the current computation state 
within the second device from the received data representation language representation of 
the current computation state of the process. The process may then resume execution 
within the second device from the current computation state. 



O 20 



Applications 



Technologies exist that allow a user to access network data from remote locations, 
making the remote data appear as local data to the user, provided the user has access to a 

25 browser. However, such technologies do not provide an automatic infrastructure to query 
networks near a client device's location. A mechanism for discovering information about 
networks and services near a client device may be desirable. For example, such a 
mechanism may be used to locate information about restaurants, weather, maps, traffic, 
movie information, etc within a certain distance (radius) of the client device, and to 

30 display desired information on the client device. An example of using this mechanism 
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may be a cell phone that can be used to automatically locate services in a local 
environment, for example, in a movie theater to display the titles and show times of 
current features in the movie theater or in a restaurant to view menu selections and prices. 
In the distributed computing environment as described herein, such a mechanism may be 
used to discover spaces including local information and/or services proximate to the 
client device. The mechanism may also be applied in other distributed computing 
environments, for example, the Jini system from Sun Microsystems, Inc. 

In one embodiment, a mobile client device may include Global Positioning 
System (GPS) capability and wireless connection technology. Local distributed 
computing networks may be provided. For example, a city may provide a citywide 
distributed computing environment. Another example may be a shopping mall with a 
local distributed computing environment. A local distributed computing network may 
include a discovery mechanism to allow client devices to connect to the distributed 
computing environment and to discover services and data in the local environment. For 
example, one or more devices in the environment may include wireless connection 
technology to allow mobile client devices to connect to the network and to access the 
discovery mechanism via the XML messaging system as described previously. A local 
distributed computing environment may include one or more spaces with advertisements 
for services and/or data to be made available to mobile clients. For example, a citywide 
distributed computing environment may include spaces that represent entities such as 
malls, movie theaters, local news, local weather, traffic, etc. A space may include 
individual service and/or data advertisements for accessing services of and information 
about the entity the space represents. The discovery mechanism may include a GPS 
location or locations of the local distributed computing environment, entities represented 
by space services within the environment, and/or the various services advertised in the 
spaces in the environment. 

In one embodiment, wired connections may be provided to a local distributed 
computing network. In this environment, a user with a mobile client device may "plug 
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in" directly to the network using a wired connection "docking station". Examples of 
wired connections include, but are not limited to: Universal Serial Bus (USB), FireWire, 
and twisted-pair Internet. In one embodiment, a docking station may also provide 
input/output capabilities such as a keyboard, mouse, and display for the mobile client 
device. In this embodiment, the location of the mobile client device may be provided to 
the lookup or discovery mechanism by the docking station. 

In one embodiment, a mobile client device may connect to a distributed 
computing network. As the user of the mobile client device navigates within wireless 
communications range of the distributed computing network, the mobile client device 
may constantly, or at various intervals, provide a location vector as input to the local 
lookup or discovery mechanism. The mobile client device may obtain the location vector 
from a GPS system built into or associated with the mobile chent. In one embodiment, 
the client may send its location information (e.g. via XML messaging) to a local service 
discovery mechanism, such as one of the space location mechanisms described herein. 
For example, the client may run the space discovery protocol specifying discovery for 
spaces offering services within a certain range of the clients location, or the client may 
instantiate a space search service to search for spaces advertising services provided for 
the client's vicinity. 

As the mobile client device moves into a specified range of a space within the 
distributed computing environment, the services and/or data stored in the space may be 
made available to the mobile client device. In embodiments where the client device 
regularly provides its location to a discovery mechanism, local services and/or data may 
automatically be made available to the client's user. In one embodiment, the specified 
range of a space may be determined by the user of the mobile client device. For example, 
the user may choose to display all restaurants within one mile of a current location. 
Alternatively, the range may be specified in the configuration of the local distributed 
computing network. For example, a citywide distributed computing network may be 
configured to provide its services to all users within three miles of the city limits. In one 
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embodiment, visual indicators, for example icons, representing the various services 
and/or data offered by the space may be displayed on the mobile client device. The client 
may then access one or more of the displayed services and/or data. In one embodiment, 
information from two or more spaces may be displayed simultaneously on the mobile 
client device. In one embodiment, the user may select v^hat services and/or data are to be 
detected. For example, in a shopping mall, a user with a mobile client device may choose 
to display all shoe stores in the mall. 

In one embodiment, executable code and/or data used in the execution of the code 
may be downloaded to the mobile client device to allow the user to execute an application 
provided by a service in the space. For example, moviegoers with mobile client devices 
may download interactive movie reviews from services in a space for the movie theater, 
and may thus perform real-time feedback about the movie they are watching. In one 
embodiment, an XML object compilation/decompilation mechanism as described 
elsewhere herein may be used to compile the code and/or data to produce XML 
representations of the code and/or data, and to decompile the XML representations to 
reproduce the code and/or data on the mobile client device. In one embodiment, an 
executable version of a process may previously exist on the mobile client device, and a 
stored state of the process may be downloaded to the mobile client device to allow the 
user to execute the process using the stored state. In one embodiment, an executable 
version of a process may previously exist on the mobile client device, and data for the 
process may be downloaded to the mobile client device. For example, data may be 
downloaded for viewing with a viewer program on the mobile client device. In one 
embodiment, an executable version of a process, including the code and data for 
executing the process, may be downloaded for execution on the mobile client device. In 
one embodiment, the service may execute the application remotely on behalf of the 
mobile client device, and the service and client may pass to each other XML messages 
including data and optionally XML schemas describing the data. In one embodiment, 
some code may be executed on the service and some on the client. For example, the 
service may execute code to perform operations on a set of data such as numerical 
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calculations. The mobile client device may execute code that may display portions of the 
data passed to the client from the service in XML messages and allov^ the user of the 
mobile client device to enter and/or select data and send the data to the service for 
performing one or more operations on the data. 

In one embodiment, a mobile client device may be connected to two or more 
services in the distributed computing network simultaneously. The services may be used 
independently or in conjunction for performing a series of tasks. For example, one 
service may be used by a remote client device to locate and/or perform operations on a set 
of data, and a second service may be used to print the set of data. 

Figure 38 illustrates a mobile client device accessing spaces in a local distributed 
computing network, according to one embodiment. A user of GPS-enabled mobile 
computing device 1700 may move into proximity of a local distributed computing 
environment. The mobile client device 1700 may provide its location provided by GPS 
1702 to one or more discovery mechanisms 1706 in the local distributed computing 
network. The discovery mechanism 1706 may use the provided GPS location of the 
mobile client device and predetermined locations of spaces within the environment to 
determine when the user moves within a specified range of one or more spaces or a 
vicinity served by one or more spaces within the environment. For example, discovery 
mechanism 1706 may determine that mobile cHent device 1700 has moved within range 
of space 1704. Discovery mechanism 1706 may then provide one or more advertisements 
1710 from space 1704 to the mobile client device 1700. Alternatively, discovery 
mechanism 1706 may provide a Universal Resource Identifier (URI) for space 1704, or 
for one or more advertisements in space 1704, to mobile client device 1700. Icons 
representing the various services advertised by service advertisements 1708 and/or data 
represented by content advertisements 1710 may then be displayed on mobile client 
device 1700. The user may then select one or more of the advertised services and/or data 
for execution and/or display on the mobile client device. The mobile computing device 
1700 may establish a wireless connection with the device offering the service and 



Atty. Dkt. No.: 5181-66100 



180 



Conley Rose & Tayon, P.C. 



communicate with the device to execute the service using the XML-based messaging 
system as previously described herein. Alternatively, the user of the mobile computing 
device 1700 may connect the device at a docking station. The location of the docking 
station may have been discovered by the user using the lookup or discovery mechanism 
1706, and spaces containing advertisements for the docking stations to discover the 
location and availability of docking stations within a specified range of the user. 

Discovery mechanism 1706 may also detect when mobile client device 1700 
moves into a selected range of space 1714. The various service advertisements 1718 and 
content advertisements 1720 may then be made available to the user of the mobile client 
device 1700. When the mobile client device moves out of the specified range of one of 
the spaces, the advertisements offered by that space may be removed from the mobile 
client device 1700's display. 

In one embodiment, advertisements on a space may include location information 
for the services or data that they provide. Thus, discovery mechanism 1706 may 
determine when mobile client device 1700 moves within a specified range of a particular 
service advertised on space 1718, and may provide (or remove) the service advertisement 
based upon the location of the mobile client device 1700. 

Computing devices are shrinking while at the same time gaining power and 
functionality. Storage devices, CPUs, RAM, I/O ASICS, power supplies, etc. have been 
reduced in size to where small, mobile client devices may include much of the 
functionality of a full-sized personal computer. However, some components of a 
computer system are not easily shrinkable because of the human factor and other factors. 
These components include, but are not limited to: keyboards, monitors, scanners, and 
printers. The limits on reducing the size of some components may prevent mobile client 
devices from truly assuming the role of personal computers. 
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In one embodiment, docking stations may be provided that allow users with 
mobile client devices to connect to and use components that are not available on the 
mobile client device because of human or other factors. For example, docking stations 
may be provided in public places such as airports or libraries. The docking stations may 
provide monitors, keyboards, printers or other devices for users with mobile client 
devices. In one embodiment, the docking stations may not fully function without help 
from a real computing device such as a mobile client device connected by a user. The 
docking station may provide services such as various input/output functions to the client 
using the computing power of the mobile client device. 

A docking station may provide one or more connection options to a mobile client 
device. The connection options may include wireless connections and wired connections. 
Examples of wireless connections include, but are not limited to: infrared such as IrDA 
and wireless network connections similar to those provided by a network interface card 
(NIC) in a notebook computer. Examples of wired connections include, but are not 
limited to: USB, Fire Wire, and twisted-pair Ethernet. 

A mobile client device may discover the location of docking stations using a 
method substantially similar to that described above for mobile client devices. The 
location of one or more docking stations in a local distributed computing network may be 
discovered using a discovery mechanism to discover spaces with advertisements for 
docking stations. The mobile client device may provide a location to the discovery 
mechanism. In one embodiment, the discovery mechanism or a lookup mechanism may 
return the location of one or more docking stations closest to the location of the mobile 
client device. Alternatively, the discovery mechanism or lookup mechanism may return a 
URI of the space containing the advertisements for the docking stations, and the mobile 
client device may then connect with the space to provide the location of the one or more 
docking stations near the device. In one embodiment, the mobile client device may 
supply information to the lookup or discovery mechanism to specify requirements such as 
monitor resolution, screen size, graphics capabilities, available devices such as printers 
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and scanners, etc. In one embodiment, information about the one or more docking 
stations may be supplied to the user on the mobile client device including availability (is 
another user using the docking station), components and capabilities of the various 
docking stations. 

When a user approaches a docking station, a claiming protocol may be initiated. 
When the claim is accepted by the docking station, secure input and output connections 
may be established between the mobile client device and the docking station. 
Alternatively, the user may select the docking station from one or more docking stations 
discovered using the lookup or discovery mechanism displayed on the mobile client 
device. When the user selects the docking station, the claiming protocol may be initiated 
to give the user secure, exclusive connection to the docking station for the duration of the 
claim. A docking station release method may also be provided to allow the user to 
terminate the session on the docking station and release the docking station for use by 
other users. In one embodiment, the claiming protocol may be a lease on the docking 
station service as described previously herein. 

Figure 39a illustrates a user of a mobile device discovering the location of 
docking stations according to one embodiment. Mobile client device 1750 may connect 
with discovery mechanism 1756. Mobile client device 1750 may provide a location 
obtained using GPS 1752 to discovery mechanism 1756. Mobile client device 1750 may 
also provide docking station requirements to discovery mechanism 1756. Discovery 
mechanism 1756 may search one or more spaces 1754 for advertisements for docking 
stations 1758 that meet the requirements of mobile client device 1750. In one 
embodiment, a lookup or discovery mechanism may locate one or more docking stations 
within a specified range of mobile device 1750 by comparing location information stored 
in advertisements 1758 with the supplied location of mobile device 1750. Discovery 
mechanism 1756 may then provide the location of one or more docking stations within a 
specified range of mobile client device 1750. Alternatively, discovery mechanism 1756 
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may locate a nearest docking station to mobile client device 1750 and provide the 
location to mobile client device 1750. 

Figure 39b illustrates a mobile client device 1750 connecting to a docking station 
1760, according to one embodiment. In one embodiment, the user may move mobile 
client device 1750 into wireless range of docking station 1760 and make a wireless 
connection to the docking station 1760. In another embodiment, the user may establish a 
wired connection to docking station 1760 by connecting one or more cables between 
docking station 1760 and mobile client device 1750. In one embodiment, a claim may be 
established to the docking station 1760 by the user of the mobile client device 1750. The 
claim may establish secure, exclusive rights to the docking station for the duration of the 
connection. In one embodiment, the claim mechanism may be a lease mechanism for a 
resource (the docking station) as described previously herein. In one embodiment, a user 
may be billed for use of the docking station. For example, the user may supply a credit 
card number as part of the process of claiming a docking station. Refer to the description 
of bill gates in the Message Gates section herein. Once connected, the user may use the 
various facilities provided by the docking station 1760 such as keyboard, monitor, printer, 
etc. Docking station 1760 may also include a connection to a local distributed computing 
network and thus may provide the user of the mobile client device 1750 connected to the 
docking station 1760 with discovery services for locating service and content 
advertisements on other devices within the network, allowing the user to locate and use 
various services and content in the distributed computing environment as described 
previously herein. 

When finished, the user may disconnect the mobile client device 1750 from the 
docking station 1760. In one embodiment, a docking station release mechanism may 
automatically be initiated when the mobile client device 1750 is disconnected from the 
docking station 1750. The release mechanism may clear any claim on the docking station 
1760 established by the user of the mobile client device 1750. In one embodiment, the 
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release mechanism may notify the discovery mechanism 1756 and/or docking station 
advertisement 1758 that the docking station is available. 

In one embodiment, a user may connect a mobile client device to a docking 
station without using the discovery mechanism. For example, a user in an airport may 
visually detect a docking station and connect a mobile client device to it. Another 
example may be a library providing a docking station room v/iih a plurality of docking 
stations for use, where users may access any of the docking stations that are available. 

Small Footprint and/or Embedded Devices 

Simple embedded or small footprint devices may have limited amounts of 
memory for storing and executing program instructions. A simple embedded device may 
need to understand a limited set of control inputs for initiating functionality of the device 
and outputs for reporting the status of the device. An example of a simple embedded 
device is a "smart" switch (such as a light switch) with embedded circuitry for controlling 
the switch and thus the device controlled by the switch. The smart switch may only need 
to understand two control requests (change the state of the device, request the state of the 
device) and to send one status message (the state of the device). The smart switch may 
manage the device to which it is connected by receiving its control requests from one or 
more control systems and reporting status messages to the one or more control systems. 

In one embodiment, the distributed computing environment may provide a 
framework (protocol) for including small devices that may not have the resource footprint 
(such as memory) necessary to implement the full protocol of the distributed computing 
environment. In one embodiment, an agent may be provided as a bridge between the 
small device-capable protocol and the full protocol. The agent may perform the full 
protocol discovery for the small device, so the device may not be required to implement 
the full discovery protocol and service activation. In one embodiment, the small device 
may only need to send service-specific messages. In one embodiment, these messages 
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may be pre-cooked on the small device, so the small device may only have to send 
messages that are part of the service activation to the agent. The agent may perform the 
service activation via the full protocol to the service and forward incoming message from 
the device to the service, and/or may forward replies from the service to the client. Thus, 
the agent may act as a service connector for the small client. 

In one embodiment of the distributed computing environment, an embedded 
device may be configured to receive a specific set of control requests in the form of XML 
messages and to send a specific set of XML messages to make requests, report status, etc. 
In one embodiment, a control system may be configured to manage a variety of devices 
by sending XML request messages specific to each device or category of device that it 
controls and by receiving XML messages from the devices. In one embodiment, one or 
more XML schemas may be used to define an embedded device's specific set of XML 
messages; the schema may be used by the embedded device and/or the control system in 
sending and receiving XML messages. 

An embedded device may include a "thin" implementation of the XML messaging 
system as previously described herein that supports the specific set of messages for 
controlling and monitoring the simple embedded device. The implementation of the 
XML messaging system may be tailored for use with small footprint, simple embedded 
devices, and thus may fit in the limited memory of the small footprint devices. In one 
embodiment, the XML messaging system may be implemented in a small footprint with a 
virtual machine targeted at small footprint embedded devices (e.g. KVM). A networking 
stack (to support the transport protocol for communications with one or more control 
systems) may be associated with the virtual machine and the XML messaging layer may 
"sit on top" of the networking stack. It is noted that this implementation of the messaging 
system may be used in other devices than small footprint or embedded devices. 

In one embodiment, static or pre-generated messages may be used for requests 
from control systems to embedded devices. The static messages may be precompiled and 
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stored in the embedded devices. An incoming message may be compared with the stored 
static messages to find a match for the message and thus to perform the function 
requested by the message, thus reducing or eliminating the need for code to parse 
incoming messages. Outgoing messages may be read directly from the stored static 
messages, thus reducing or eliminating the need to dynamically compile outgoing 
messages. Thus, static messages may be used to reduce the code footprint of the 
messaging layer in embedded systems. For example, static Java objects (Java op codes) 
may be used for request and status messages. 

Figure 40a illustrates an embodiment of embedded devices 1804a and 1804b 
controlled by a control system 1800, according to one embodiment. Control system 1800 
may be networked with the devices 1804a and 1804b it controls in any of a variety of 
ways. The network 1810 may be wired (Ethernet, coaxial, twisted pair, power grid, etc.) 
and/or wireless (IrDA, microwave, etc.). In one embodiment, embedded devices 1804a 
and 1804b may include a thin implementation of the XML messaging system for 
communicating with control system 1800 over network 1810. Control system 1800 may 
have an implementation of the XML messaging system for sending requests to and 
receiving responses from embedded devices 1804a and 1804b. In one embodiment, 
control system 1800 may include software and hardware configured to present an 
interface to allow a user to display the status of and remotely control the embedded 
devices 1804a and 1804b. In one embodiment, control system 1800 may include 
software and/or hardware for automatic control of embedded devices 1804a and 1804b. 

In one embodiment, embedded devices 1804a and 1804b may be part of another 
environment. The devices may not support the message passing model implemented by 
the distributed network environment. For example, the devices may be nodes in a 
networked automation and control system such as a LonWorks network. Control system 
1800 may include a control system hardware and/or software for controlling devices in 
the other environment. Control system 1800 may serve as a bridge between the 
distributed computing environment and the other environment. The distributed computing 
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environment may also provide a method or methods to wrap existing device discovery 
protocols for discovering the devices for access from the distributed network 
environment. Bridging and wrapping protocols are further described herein in the 
Bridging section. 

5 

Control system 1800 may be connected remotely or locally to one or more other 
systems in the distributed computing environment. Figure 40a shows control system 1800 
connected to client 1806 via the Internet 1802. Client 1806 may indirectly request the 
status of, and send control requests to, embedded devices 1804a and 1804b through 
10 control system 1800. Thus, control system 1800 may serve as a proxy or bridge for 
embedded devices 1804a and 1804b. See the Bridging section herein. To enable 
sophisticated conraiunication between the client 1806 and the control system 1800, the 

client and the control system may have different implementations of the XML messaging 

01 

system than the thin implementation on the embedded devices 1804a and 1804b. In one 
^ 15 embodiment, client 1806 may include software and hardware configured to present an 

M interface to allow a user of client 1806 to display the status of and remotely control the 

B embedded devices 1804a and 1804b. In one embodiment, client 1806 must present the 

correct authorization credentials to control system 1800 to enable the client 1806 to 



access embedded devices 1804a and 1804b. In one embodiment, client 1806 may be 



20 granted access at different levels. For example, client 1806 may only be able to view the 
status of embedded devices 1804a and 1804b but not be allowed to remotely control the 
devices. In one embodiment, control system 1800 may be a service, may have a service 
advertisement published in the distributed computing environment, and thus may be 
accessed by client 1806 using the client-service method as described previously in this 

25 document. In one embodiment, client 1806 may be able to view the status of, and to 
remotely control, control system 1800. 

Figure 40b illustrates client control system 1808 connected via the Internet 1802 
to embedded devices 1804c and 1804d, according to one embodiment. In one 
30 embodiment, embedded devices 1804c and 1804d may include a thin implementation of 



Atty. Dkt. No.: 5181-66100 



188 



Conley Rose & Tayon, P.C. 



the XML messaging system for communicating with client control system 1808 over the 
Internet 1802. Client control system 1808 may have an implementation of the XML 
messaging system for sending requests to and receiving responses from embedded 
devices 1804c and 1804d. In one embodiment, client control system 1808 may include 
software and hardware configured to present an interface to allow a user to display the 
status of and remotely control the embedded devices 1804c and 1804d. In one 
embodiment, client control system 1800 may include software and/or hardware for 
automatic control of embedded devices 1804c and 1804d. 

A difference between Figure 40a and Figure 40b is that, in the embodiment 
illustrated in Figure 40b, the embedded devices 1804c and 1804d may be accessed by one 
or more clients in the distributed computing environment without requiring a proxy (e.g. 
control system). Embedded devices 1804c and 1804d may include services for accessing 
the functionality of the devices, may have published service advertisements in the 
distributed computing environment, and thus may be accessed via the client-service 
method as described previously in this document. 

The distributed computing environment may include a mechanism for a resource- 
limited client to retrieve Universal Resource Identifier (URI) addressed resources. For 
example, a client that is only capable of sending and receiving messages via an IrDA 
connection may not be able to establish a URI connection to retrieve results from a results 
space. In one embodiment, a service may be provided as a bridge between the client and 
the URI resource. The bridge service may interact with the client via XML messages to 
gather input parameters. The following is included as an example of an XML input 
message syntax and is not intended to be limiting in any way: 

<type name="HttpGet"> 

<element name="urlstring" type="string"/> 
</type> 
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Then, outside the distributed computing environment, the bridge service may 
establish a URI connection and retrieve the resource. The resource may then be 
encapsulated as a payload in one or more XML messages and sent to the client by the 
bridge service. 

The following illustration of one possible use of embedded devices with thin 
implementations of the XML messaging system is included for exemplary purposes and is 
not intended to be limiting. A building may include a plurality of electronic devices that 
consume energy (e.g. lights, air conditioners, office equipment), and thus may require a 
system for maintaining an optimum energy consumption level. The plurality of devices 
may each include an embedded device for controlling the electronic devices. The 
embedded devices may include the thin implementation of the XML messaging system. 
One or more control systems may be coupled to the devices in a network, for example, a 
building LAN or even the Internet. A control system may store and execute a building 
management software package and an implementation of the XML messaging system 
configured to be used by the software package for monitoring and controlling the devices. 
The control system may accept input from users, and may display and otherwise output 
status information for the building energy consumption system, including status 
information for each of the plurality of devices. Energy consumption may be monitored 
by receiving XML status messages from each of the plurality of devices. When energy 
consumption levels need to be adjusted, XML control messages may be sent to one or 
more of the devices to cause the energy consumption to change. 

Implementing Services 

In one embodiment, the distributed computing environment may provide a 
mechanism for implementing services as servlets. The mechanism may provide 
functionality for developing services for the distributed computing environment. 
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In one embodiment, an Application Programming Interface (API) may be 
provided that provides the functionality to allov^ the service to be initialized and 
registered in a space. In one embodiment, the API may be used to invoke the 
initialization of the service and to generate an initialization status page, for example, an 
HTML page, that may define the status of the service. A user may access the status of the 
service by accessing the status page from a browser. In one embodiment, the API may be 
used to process incoming messages and to generate documents in response to the 
messages. 

An embodiment of the servlet mechanism may provide several functions 
including, but not limited to: 

• Management of the client connection to the service (unique session ID) 

• Management of an activation space that may be used to store results 
advertisements 

• Management of leases on connections sessions and results in activation spaces 

• Garbage collection of sessions and results 

• Authentication of clients 

• Generation of client capabilities on a per session basis 

In one embodiment, the distributed computing environment may provide a service 
cascading mechanism by which new, complex services may be constructed from other 
existing services. For example, from a JPG-to-PostScript transformation service and a 
print service, a third cascaded service may be created by combining the transformation 
and print service. In one embodiment, two or more services may be combined into a 
complex service by defining access methods of the two or more services as the access 
methods of the cascaded service. 

Conclusion 
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Various embodiments may further include receiving, sending or storing 
instructions and/or data implemented in accordance with the foregoing description upon a 
carrier medium. Generally speaking, a carrier medium may include storage media or 
memory media such as magnetic or optical media, e.g., disk or CD-ROM, volatile or non- 
volatile media such as RAM (e.g. SDRAM, RDRAM, SRAM, etc.), ROM, etc. as well as 
transmission media or signals such as electrical, electromagnetic, or digital signals, 
conveyed via a communication medium such as network and/or a wireless Hnk. 

Various modifications and changes may be made as would be obvious to a person 
skilled in the art having the benefit of this disclosure. It is intended that the invention 
embraces all such modifications and changes and, accordingly, the specifications, 
appendices and drawings are to be regarded in an illustrative rather than a restrictive 
sense. 
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